Kaedah konfigurasi asas rentas domain proksi terbalik Nginx
konfigurasi asas proksi terbalik perkhidmatan antara muka nginx
server { listen 8443; # 监听的端口号 server_name a.test.com; # 服务器名称 client_max_body_size 100m; # 定义读取客户端请求头的超时时间 ssl on; ssl_certificate test.pem; ssl_certificate_key test.key; ssl_session_timeout 5m; ssl_protocols sslv3 tlsv1.2; ssl_ciphers ecdhe-rsa-aes256-sha384:aes256-sha256:rc4:high:!md5:!anull:!enull:!null:!dh:!edh:!aesgcm; ssl_prefer_server_ciphers on; location / { root /test-static-app; # 静态资源目录 index index.html index.htm; try_files $uri $uri/ /index.html; # 动态解析目录,配合vue的history模式 } }
Konfigurasi asas melaksanakan fungsi asas halaman dan pelayan statik, dan boleh melaksanakan penghalaan apabila menggunakan parse mod sejarah vue . Tambahan pula, untuk mencapai pemajuan bersatu ke pelayan antara muka, kita perlu menentukan awalan nama antara muka dengan pembangun bahagian belakang Sebagai contoh, laluan relatif semua antara muka pada masa ini, kita boleh menambah konfigurasi berikut (sama dengan lokasi sebelumnya ),
... location /api { proxy_pass https://b.test.com; # 设置代理服务器的协议和地址 proxy_cookie_domain b.test.com a.test.com; # 修改cookie,针对request和response互相写入cookie } ...
Ia bergantung terutamanya pada proxy_pass untuk memajukan antara muka /api/x di bawah a.test.com ke b.test.com Prosesnya adalah seperti berikut
Interaksi kuki terutamanya proxy_cookie_domain, ditambah dengan perenggan berikut
proxy_cookie_domain b.test.com a.test.com;
Ini merealisasikan pemindahan dan tulis balik kuki antara a.test. com dan nama domain b.test.com.
Jika anda menggunakan nod untuk mensimulasikannya, ia adalah kira-kira seperti berikut
module.exports = (router) => { router.get('/api/index/getcmsinfo', async function (ctx, next) { // 接口转发 let result = await superagent.post('https://b.test.com/api/card/home').set(browsermsg) // 获取返回的set-cookie,并设置header let setcookie = result.headers['set-cookie'] if (setcookie) { ctx.response.header['set-cookie'] = setcookie } // 返回 ctx.response.body={ success: true, result: result.body } }) }
Ringkasnya, intipati proksi terbalik nginx sebenarnya adalah pemajuan perkhidmatan antara muka dan pemprosesan pengepalanya mudah difahami jika anda memikirkannya dengan teliti.
Salah Faham Biasa
Aca-header yang tidak berguna?
Banyak tetapan merentas domain nginx di Internet termasuk kandungan yang berkaitan dengan tetapan pengepala merentas domain, seperti
add_header 'access-control-allow-origin' '*'; add_header 'access-control-allow-credentials' "true"; add_header access-control-allow-headers x-requested-with;
Fikirkan tentang prinsip di atas, adakah anda fikir ini masih berguna ? Tajuk siri aca (akses-kawalan-benarkan-) dikonfigurasikan untuk rundingan merentas domain dalam CORS. Anda tidak perlu menanggalkan seluar dan kentut di sini.
2. Adakah nama domain proxy_pass mengandungi ‘slash/’?
Begitu juga, saya melihat di Internet bahawa apabila mengkonfigurasi proxy_pass, sesetengah netizen akan menambah garis miring pada penghujungnya, seperti yang ditunjukkan di bawah, dan kemudian mengatakan bahawa ralat telah dilaporkan dan antara muka tidak ditemui ~ Apa yang perlu saya lakukan~
... location /api { #proxy_pass https://b.test.com; proxy_pass https://b.test.com/; } ...
Mari kita fikirkan selepas melihat ini Fungsi proxy_pass adalah untuk menangkap permintaan Menambah slash bermakna semua permintaan /api akan dimajukan ke direktori root, yang bermaksud /api akan menjadi / Sebaliknya, laluan antara muka telah berubah pada masa ini, dan terdapat kurang satu lapisan/api. Bagaimana dengan tanpa menambah garis miring? Ini bermakna apabila dimajukan ke nama domain b.test.com, laluan /api tidak akan hilang.
Dalam kes ini, jika antara muka hujung belakang mempunyai awalan yang ditetapkan, seperti /api, maka anda tidak perlu mengkonfigurasi garis miring di sini. Dalam kes lain, antara muka bahagian belakang adalah sama, tanpa awalan bersatu Kita perlu membezakannya di sini Kemudian tambahkan awalan bersatu pada semua antara muka bahagian hadapan, seperti /api, dan kemudian gantikannya dengan menambahkan garis miring. ~
Atas ialah kandungan terperinci Kaedah konfigurasi asas rentas domain proksi terbalik Nginx. 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

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

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





Cara mengkonfigurasi nama domain Nginx pada pelayan awan: Buat rekod yang menunjuk ke alamat IP awam pelayan awan. Tambah blok hos maya dalam fail konfigurasi Nginx, menyatakan port pendengaran, nama domain, dan direktori akar laman web. Mulakan semula nginx untuk memohon perubahan. Akses konfigurasi ujian nama domain. Nota Lain: Pasang sijil SSL untuk membolehkan HTTPS, pastikan firewall membenarkan trafik port 80, dan tunggu resolusi DNS berkuatkuasa.

Bagaimana untuk mengesahkan sama ada nginx dimulakan: 1. Gunakan baris arahan: status sistem sistem nginx (linux/unix), netstat -ano | Findstr 80 (Windows); 2. Periksa sama ada port 80 dibuka; 3. Semak mesej permulaan Nginx dalam log sistem; 4. Gunakan alat pihak ketiga, seperti Nagios, Zabbix, dan Icinga.

Anda boleh menanyakan nama kontena Docker dengan mengikuti langkah -langkah: Senaraikan semua bekas (Docker PS). Tapis senarai kontena (menggunakan arahan grep). Mendapat nama kontena (terletak di lajur "Nama").

Kaedah yang boleh menanyakan versi nginx adalah: gunakan perintah nginx -v; Lihat arahan versi dalam fail nginx.conf; Buka halaman ralat Nginx dan lihat tajuk halaman.

Memulakan pelayan Nginx memerlukan langkah-langkah yang berbeza mengikut sistem operasi yang berbeza: Sistem Linux/Unix: Pasang pakej Nginx (contohnya, menggunakan apt-get atau yum). Gunakan SystemCTL untuk memulakan perkhidmatan Nginx (contohnya, SUDO SystemCTL Mula Nginx). Sistem Windows: Muat turun dan pasang fail binari Windows. Mula Nginx menggunakan nginx.exe executable (contohnya, nginx.exe -c conf \ nginx.conf). Tidak kira sistem operasi yang anda gunakan, anda boleh mengakses IP pelayan

Bagaimana cara mengkonfigurasi nginx di Windows? Pasang Nginx dan buat konfigurasi hos maya. Ubah suai fail konfigurasi utama dan sertakan konfigurasi hos maya. Mulakan atau Muat semula Nginx. Uji konfigurasi dan lihat laman web. Selektif membolehkan SSL dan mengkonfigurasi sijil SSL. Selektif tetapkan firewall untuk membolehkan trafik port 80 dan 443.

Buat bekas di Docker: 1. Tarik Imej: Docker Pull [Nama Cermin] 2. Buat bekas: Docker Run [Options] [Mirror Name] [Command] 3. Mulailah bekas: Docker Start [Nama Container]

Docker Container Startup Langkah: Tarik Imej Bekas: Run "Docker Pull [Mirror Name]". Buat bekas: Gunakan "Docker Buat [Pilihan] [Nama Mirror] [Perintah dan Parameter]". Mulakan bekas: Jalankan "Docker Start [Nama Container atau ID]". Semak Status Kontena: Sahkan bahawa bekas sedang berjalan dengan "Docker PS".
