


Bagaimana untuk mengkonfigurasi proksi terbalik Nginx menggunakan SSL
Prasyarat
1. Backend Server: Untuk tujuan tutorial ini, kami menggunakan pelayan tomcat yang berjalan pada localhost pada port 8080
Nota: - Apabila anda memulakan permintaan proksi, pastikan pelayan aplikasi dimulakan.
Sijil 2.ssl: Kami juga perlu mengkonfigurasi sijil ssl pada pelayan. Kami boleh menggunakan sijil penyulitan let's encryption, anda boleh mendapatkannya menggunakan program yang disebutkan di sini. Tetapi untuk tutorial ini kita akan menggunakan sijil yang ditandatangani sendiri yang boleh dibuat dengan menjalankan arahan berikut dari terminal,
$ openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout /etc/nginx/certs/cert.key -out /etc/nginx/certs/cert.crt
Langkah seterusnya dalam mengkonfigurasi proksi terbalik nginx dengan ssl ialah pemasangan nginx,
Pasang nginx
ubuntu
nginx tersedia dalam repositori ubuntu lalai. Jadi mudah, pasangnya menggunakan arahan berikut,
$ sudo apt-get update && sudo apt-get install nginx
Sekarang mulakan perkhidmatan dan dayakannya untuk permulaan,
# systemctl start nginx # systemctl enable nginx
Sekarang semak pemasangan nginx, kita boleh membuka pelayar web dan masuk ke sistem ip sebagai url untuk mendapatkan halaman web nginx lalai, ini mengesahkan bahawa nginx berfungsi dengan betul.
Konfigurasikan proksi terbalik nginx menggunakan ssl
Kini kami mempunyai semua yang kami perlukan untuk mengkonfigurasi proksi terbalik nginx menggunakan ssl. Kami kini perlu mengkonfigurasi dalam nginx, kami akan menggunakan fail konfigurasi nginx lalai iaitu /etc/nginx/conf.d/default.conf.
Dengan mengandaikan ini adalah kali pertama kami membuat sebarang perubahan pada konfigurasi , buka fail dan padam atau ulas semua kandungan fail lama, kemudian masukkan entri berikut ke dalam fail.
vi /etc/nginx/conf.d/default.conf
server { listen 80; return 301 https://$host$request_uri; } server { listen 443; server_name linuxtechlab.com; ssl_certificate /etc/nginx/ssl/cert.crt; ssl_certificate_key /etc/nginx/ssl/cert.key; ssl on; ssl_session_cache builtin:1000 shared:ssl:10m; ssl_protocols tlsv1 tlsv1.1 tlsv1.2; ssl_ciphers high:!anull:!enull:!export:!camellia:!des:!md5:!psk:!rc4; ssl_prefer_server_ciphers on; access_log /var/log/nginx/access.log; location / { proxy_set_header host $host; proxy_set_header x-real-ip $remote_addr; proxy_set_header x-forwarded-for $proxy_add_x_forwarded_for; proxy_set_header x-forwarded-proto $scheme; proxy_pass http://localhost:8080; proxy_read_timeout 90; proxy_redirect http://localhost:8080 https://linuxtechlab.com; } }
Selepas anda membuat semua perubahan, simpan fail dan keluar. Kami akan membincangkan konfigurasi yang kami buat bahagian demi bahagian sebelum kami memulakan semula perkhidmatan nginx untuk melaksanakan perubahan.
Bahagian 1
server { listen 80; return 301 https://$host$request_uri; }
Di sini kami memberitahu bahawa kami ingin mendengar sebarang permintaan ke port 80 dan kemudian mengubah halanya ke https.
Bahagian 2
listen 443; server_name linuxtechlab.com; ssl_certificate /etc/nginx/ssl/cert.crt; ssl_certificate_key /etc/nginx/ssl/cert.key; ssl on; ssl_session_cache builtin:1000 shared:ssl:10m; ssl_protocols tlsv1 tlsv1.1 tlsv1.2; ssl_ciphers high:!anull:!enull:!export:!camellia:!des:!md5:!psk:!rc4; ssl_prefer_server_ciphers on;
Kini ini adalah beberapa pilihan ssl nginx lalai yang kami gunakan, mereka memberitahu pelayan web nginx versi protokol mana, sifir ssl disokong.
Bahagian 3
location / { proxy_set_header host $host; proxy_set_header x-real-ip $remote_addr; proxy_set_header x-forwarded-for $proxy_add_x_forwarded_for; proxy_set_header x-forwarded-proto $scheme; proxy_pass http://localhost:8080; proxy_read_timeout 90; proxy_redirect http://localhost:8080 https://linuxtechlab.com; }
Kini, bahagian ini merangkumi proksi dan ke mana permintaan masuk pergi sebaik sahaja ia masuk. Sekarang bahawa kita telah membincangkan semua konfigurasi, kita akan menyemak dan kemudian memulakan semula perkhidmatan nginx.
Untuk menyemak nginx, jalankan arahan berikut
# nginx -t
Setelah semua fail konfigurasi kami ok, kami akan memulakan semula perkhidmatan nginx
# systemctl restart nginx
Itu sahaja , proksi terbalik ssl nginx kami kini sedia. Sekarang untuk menguji persediaan, anda hanya perlu membuka pelayar web dan masukkan url. Kita kini harus dialihkan ke halaman web apache tomcat.
Atas ialah kandungan terperinci Bagaimana untuk mengkonfigurasi proksi terbalik Nginx menggunakan SSL. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Untuk membenarkan pelayan Tomcat mengakses rangkaian luaran, anda perlu: mengubah suai fail konfigurasi Tomcat untuk membenarkan sambungan luaran. Tambahkan peraturan tembok api untuk membenarkan akses kepada port pelayan Tomcat. Buat rekod DNS yang menunjukkan nama domain ke IP awam pelayan Tomcat. Pilihan: Gunakan proksi terbalik untuk meningkatkan keselamatan dan prestasi. Pilihan: Sediakan HTTPS untuk meningkatkan keselamatan.

Langkah-langkah untuk menjalankan ThinkPHP Framework secara setempat: Muat turun dan nyahzip ThinkPHP Framework ke direktori tempatan. Buat hos maya (pilihan) yang menunjuk ke direktori akar ThinkPHP. Konfigurasikan parameter sambungan pangkalan data. Mulakan pelayan web. Mulakan aplikasi ThinkPHP. Akses URL aplikasi ThinkPHP dan jalankannya.

Untuk menyelesaikan ralat "Selamat datang ke nginx!", anda perlu menyemak konfigurasi hos maya, dayakan hos maya, muat semula Nginx, jika fail konfigurasi hos maya tidak dapat ditemui, buat halaman lalai dan muat semula Nginx, kemudian mesej ralat akan hilang dan laman web akan menjadi paparan biasa.

Terdapat lima kaedah untuk komunikasi kontena dalam persekitaran Docker: rangkaian kongsi, Karang Docker, proksi rangkaian, volum dikongsi dan baris gilir mesej. Bergantung pada keperluan pengasingan dan keselamatan anda, pilih kaedah komunikasi yang paling sesuai, seperti memanfaatkan Docker Compose untuk memudahkan sambungan atau menggunakan proksi rangkaian untuk meningkatkan pengasingan.

Untuk mendaftar untuk phpMyAdmin, anda perlu terlebih dahulu mencipta pengguna MySQL dan memberikan kebenaran kepadanya, kemudian memuat turun, memasang dan mengkonfigurasi phpMyAdmin, dan akhirnya log masuk ke phpMyAdmin untuk mengurus pangkalan data.

Langkah-langkah penggunaan pelayan untuk projek Node.js: Sediakan persekitaran penggunaan: dapatkan akses pelayan, pasang Node.js, sediakan repositori Git. Bina aplikasi: Gunakan npm run build untuk menjana kod dan kebergantungan yang boleh digunakan. Muat naik kod ke pelayan: melalui Git atau Protokol Pemindahan Fail. Pasang kebergantungan: SSH ke dalam pelayan dan gunakan pemasangan npm untuk memasang kebergantungan aplikasi. Mulakan aplikasi: Gunakan arahan seperti node index.js untuk memulakan aplikasi, atau gunakan pengurus proses seperti pm2. Konfigurasikan proksi terbalik (pilihan): Gunakan proksi terbalik seperti Nginx atau Apache untuk menghalakan trafik ke aplikasi anda

Menukar fail HTML kepada URL memerlukan pelayan web, yang melibatkan langkah berikut: Dapatkan pelayan web. Sediakan pelayan web. Muat naik fail HTML. Buat nama domain. Halakan permintaan.

Langkah penyelesaian masalah untuk pemasangan phpMyAdmin yang gagal: Semak keperluan sistem (versi PHP, versi MySQL, pelayan web dayakan sambungan PHP (mysqli, pdo_mysql, mbstring, token_get_all semak tetapan fail konfigurasi (hos, port, nama pengguna, kata laluan); kebenaran (pemilikan direktori, keizinan fail); phpMyAdmin
