Bagaimana Nginx melaksanakan konfigurasi WebSocket
Sebagai pelayan web berprestasi tinggi dan pelayan proksi terbalik, Nginx juga mempunyai kaedah konfigurasi uniknya sendiri dalam mengendalikan permintaan WebSocket. WebSocket ialah protokol berasaskan TCP Penubuhan sambungan WebSocket memerlukan jabat tangan tiga hala Selepas jabat tangan selesai, komunikasi dua hala boleh berlaku antara klien dan pelayan. Di bawah, kami akan memperkenalkan cara melaksanakan konfigurasi WebSocket dalam Nginx, dengan contoh kod khusus.
Pertama, anda perlu menambah konfigurasi berkaitan WebSocket pada fail konfigurasi Nginx.
http { ... upstream websocket { server localhost:9001; } ... map $http_upgrade $connection_upgrade { default upgrade; '' close; } ... server { listen 80; server_name example.com; location / { proxy_pass http://websocket; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection $connection_upgrade; proxy_set_header Host $host; } ... } ... }
Dalam konfigurasi di atas, kami menambah huluan bernama "websocket" untuk menentukan alamat pelayan sasaran dan port WebSocket. Pada masa yang sama, arahan peta digunakan untuk memetakan $http_upgrade (pengepala permintaan naik taraf pelanggan) dan $connection_upgrade (pengepala permintaan naik taraf nginx). Dengan cara ini, dengan menambahkan medan "Naik Taraf" dan "Sambungan" pada pengepala permintaan naik taraf pelanggan, Nginx boleh dicetuskan untuk menaik taraf protokol HTTP kepada protokol WebSocket, sekali gus mencapai komunikasi dua hala.
Dalam blok pelayan, kami menggunakan arahan proxy_pass untuk memproksi semua permintaan WebSocket ke huluan soket web, dan menetapkan versi protokol dan meminta maklumat pengepala. Perlu diingat bahawa apabila membuat proksi WebSocket dalam Nginx, pengepala permintaan "Naik taraf" dan "Sambungan" mesti dihantar ke pelayan sasaran bersama-sama, jika tidak sambungan akan ditutup, jadi kedua-dua pengepala permintaan ini mesti ditetapkan secara manual melalui arahan proxy_set_header .
Selain itu, perlu diperhatikan bahawa dalam konfigurasi di atas, kami hanya mendengar port HTTP (80) Jika anda perlu mengkonfigurasi WebSocket di bawah HTTPS, anda perlu menambah arahan berikut dalam blok pelayan:
listen 443 ssl; ssl_certificate /path/to/cert.pem; ssl_certificate_key /path/to/key.pem;
. Arahan di atas digunakan untuk memantau port HTTPS (443), dan menentukan laluan dan nama sijil dan fail kunci.
Berikut ialah contoh kod pelayan WebSocket khusus, dilaksanakan menggunakan Node.js:
const WebSocket = require('ws'); const server = new WebSocket.Server({ port: 9001 }); server.on('connection', (socket, req) => { console.log('Client connected'); socket.on('message', (message) => { console.log(`Received message: ${message}`); socket.send(`Your message: ${message}`); }); socket.on('close', () => { console.log('Client disconnected'); }); });
Dalam kod ini, kami mencipta pelayan WebSocket dan mendengar port 9001. Selepas sambungan diwujudkan, kami mengeluarkan maklumat "Pelanggan disambungkan", dan selepas menerima mesej pelanggan, kembalikan mesej itu kepada pelanggan, kemudian dengar acara penutup, dan keluarkan maklumat "Pelanggan diputuskan".
Dengan contoh kod dan konfigurasi di atas, kami boleh melaksanakan kerja proksi dan komunikasi protokol WebSocket dalam Nginx. Perlu diingatkan bahawa masih terdapat sekatan tertentu pada penggunaan protokol WebSocket Secara khusus, proses penubuhan sambungan WebSocket adalah serupa dengan protokol HTTP/HTTPS Walau bagaimanapun, apabila sambungan berjaya diwujudkan, komunikasi antara kedua-duanya pihak bergantung sepenuhnya pada protokol WebSocket Ia tidak lagi bergantung pada protokol HTTP/HTTPS. Oleh itu, apabila menggunakan protokol WebSocket, anda perlu mengelakkan beberapa sekatan pembangunan Web konvensional, dan pada masa yang sama, anda juga mesti memberi perhatian kepada isu seperti keselamatan dan kestabilan.
Atas ialah kandungan terperinci Bagaimana Nginx melaksanakan konfigurasi WebSocket. 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



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.

Langkah -langkah untuk memulakan Nginx di Linux: Periksa sama ada Nginx dipasang. Gunakan SistemCTL Mula Nginx untuk memulakan perkhidmatan Nginx. Gunakan SistemCTL Dayakan NGINX untuk membolehkan permulaan automatik Nginx pada permulaan sistem. Gunakan Status SistemCTL Nginx untuk mengesahkan bahawa permulaan berjaya. Lawati http: // localhost dalam pelayar web untuk melihat halaman selamat datang lalai.

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.

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

Pelayan tidak mempunyai kebenaran untuk mengakses sumber yang diminta, mengakibatkan ralat NGINX 403. Penyelesaian termasuk: Periksa keizinan fail. Semak konfigurasi .htaccess. Semak konfigurasi Nginx. Konfigurasikan keizinan Selinux. Semak peraturan firewall. Menyelesaikan masalah lain seperti masalah penyemak imbas, kegagalan pelayan, atau kesilapan lain yang mungkin.

Jawab kepada Soalan: 304 Tidak diubahsuai ralat menunjukkan bahawa penyemak imbas telah cache versi sumber terkini permintaan klien. Penyelesaian: 1. Kosongkan cache penyemak imbas; 2. Lumpuhkan cache penyemak imbas; 3. Konfigurasi nginx untuk membolehkan cache pelanggan; 4. Periksa keizinan fail; 5. Semak fail hash; 6. Lumpuhkan CDN atau cache proksi terbalik; 7. Mulakan semula nginx.

Di Linux, gunakan arahan berikut untuk memeriksa sama ada nginx dimulakan: Hakim status SistemCTL Nginx berdasarkan output arahan: Jika "Aktif: Aktif (Running)" dipaparkan, Nginx dimulakan. Jika "aktif: tidak aktif (mati)" dipaparkan, nginx dihentikan.

Bagaimana untuk memperbaiki kesilapan dilarang nginx 403? Semak keizinan fail atau direktori; 2. Semak .htaccess File; 3. Semak fail konfigurasi nginx; 4. Mulakan semula nginx. Penyebab lain yang mungkin termasuk peraturan firewall, tetapan selinux, atau isu aplikasi.
