Maison développement back-end tutoriel php Comment utiliser le serveur proxy Nginx pour implémenter la prise en charge du protocole WebSocket ?

Comment utiliser le serveur proxy Nginx pour implémenter la prise en charge du protocole WebSocket ?

Sep 05, 2023 am 08:06 AM
nginx websocket 代理

Comment utiliser le serveur proxy Nginx pour implémenter la prise en charge du protocole WebSocket ?

Comment utiliser le serveur proxy Nginx pour implémenter le support du protocole WebSocket ?

WebSocket est un protocole de communication full-duplex basé sur TCP. Il permet au serveur et au client d'établir une communication bidirectionnelle en temps réel en établissant un canal de communication dans lequel les deux parties peuvent maintenir une connexion à long terme. communication en temps réel, chat instantané, scénarios tels que la transmission de données en temps réel. Lors de l'utilisation de WebSocket, nous devons souvent configurer le serveur proxy pour transférer les requêtes et les réponses WebSocket. Cet article explique comment utiliser le serveur proxy Nginx pour implémenter la prise en charge du protocole WebSocket.

Étape 1 : Installer Nginx

Tout d'abord, nous devons nous assurer que Nginx est installé sur le serveur proxy. S'il n'est pas installé, veuillez choisir la méthode d'installation appropriée en fonction du système d'exploitation.

Étape 2 : Modifier le fichier de configuration Nginx

Ensuite, nous devons modifier le fichier de configuration Nginx. Ouvrez le fichier de configuration Nginx et ajoutez le code suivant dans le bloc http : http块中添加以下代码:

map $http_upgrade $connection_upgrade {
    default upgrade;
    ''      close;
}

upstream backend {
    server 127.0.0.1:8080;
}
Copier après la connexion

上述代码中,map指令用于将请求头中的Upgrade字段的值映射为$connection_upgrade变量的值。upstream指令用于定义后端服务器的地址,这里使用的是本地地址127.0.0.1:8080,你可以根据实际情况进行修改。

server块中添加以下代码:

location /websocket {
    proxy_pass http://backend;
    proxy_http_version 1.1;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection $connection_upgrade;
}
Copier après la connexion

上述代码中,location指令用于匹配WebSocket请求的路径。proxy_pass指令用于将请求转发给后端服务器。proxy_http_version指令用于指定代理协议的版本。proxy_set_header指令用于设置请求头,将UpgradeConnection

sudo service nginx restart
Copier après la connexion

Dans le code ci-dessus, la directive map est utilisée pour modifier le Upgrade< / dans l'en-tête de la requête La valeur du champ code> est mappée à la valeur de la variable <code>$connection_upgrade. La directive upstream est utilisée pour définir l'adresse du serveur backend. L'adresse locale 127.0.0.1:8080 est utilisée ici. Vous pouvez la modifier en fonction de la situation réelle.

Ajoutez le code suivant dans le bloc server :

var ws = new WebSocket("ws://your_domain/websocket");

ws.onopen = function() {
    console.log("Connected to WebSocket");
};

ws.onmessage = function(event) {
    console.log("Received message: " + event.data);
};

ws.onclose = function() {
    console.log("Disconnected from WebSocket");
};
Copier après la connexion
Dans le code ci-dessus, la directive location est utilisée pour correspondre au chemin de la requête WebSocket. La directive proxy_pass est utilisée pour transmettre la requête au serveur backend. La directive proxy_http_version est utilisée pour spécifier la version du protocole proxy. La directive proxy_set_header est utilisée pour définir l'en-tête de la requête et transmettre les champs Upgrade et Connection au serveur backend tels quels.

Étape 3 : Redémarrez le service Nginx

Après avoir terminé la modification du fichier de configuration, enregistrez et fermez le fichier. Ensuite, redémarrez le service Nginx pour que la configuration prenne effet. Entrez la commande suivante dans la ligne de commande :

rrreee

Étape 4 : Testez la connexion WebSocket

À ce stade, nous avons terminé la configuration de Nginx. Ensuite, nous pouvons utiliser l'outil client WebSocket ou écrire une simple application Web pour tester la connexion WebSocket. Voici un exemple de code simple : 🎜rrreee🎜 Enregistrez le code ci-dessus sous forme de fichier HTML et ouvrez le fichier dans votre navigateur. Si vous voyez le résultat « Connecté à WebSocket » dans les outils de développement du navigateur, cela signifie que la connexion WebSocket a réussi. 🎜🎜Résumé : Grâce aux étapes ci-dessus, nous avons utilisé avec succès le serveur proxy Nginx pour implémenter la prise en charge du protocole WebSocket. De cette façon, nous pouvons utiliser les performances puissantes et la configuration flexible de Nginx pour obtenir une communication WebSocket plus efficace et plus stable. Cependant, il convient de noter que Nginx lui-même n'est pas un serveur WebSocket. Il est uniquement utilisé comme serveur proxy pour transférer les connexions WebSocket vers le serveur principal pour traitement. Si vous devez déployer un serveur WebSocket complet, nous pouvons envisager d'utiliser un autre logiciel serveur WebSocket dédié. 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment configurer le nom de domaine du serveur cloud dans nginx Comment configurer le nom de domaine du serveur cloud dans nginx Apr 14, 2025 pm 12:18 PM

Comment configurer un nom de domaine NGINX sur un serveur cloud: Créez un enregistrement A pointant vers l'adresse IP publique du serveur cloud. Ajoutez des blocs d'hôtes virtuels dans le fichier de configuration Nginx, en spécifiant le port d'écoute, le nom de domaine et le répertoire racine du site Web. Redémarrez Nginx pour appliquer les modifications. Accéder à la configuration du test de nom de domaine. Autres notes: Installez le certificat SSL pour activer HTTPS, assurez-vous que le pare-feu autorise le trafic Port 80 et attendez que la résolution DNS prenne effet.

Comment démarrer le serveur Nginx Comment démarrer le serveur Nginx Apr 14, 2025 pm 12:27 PM

Le démarrage d'un serveur Nginx nécessite différentes étapes en fonction des différents systèmes d'exploitation: Système Linux / Unix: Installez le package NGINX (par exemple, en utilisant Apt-Get ou Yum). Utilisez SystemCTL pour démarrer un service NGINX (par exemple, sudo systemctl start nginx). Système Windows: téléchargez et installez les fichiers binaires Windows. Démarrer Nginx à l'aide de l'exécutable Nginx.exe (par exemple, nginx.exe -c conf \ nginx.conf). Peu importe le système d'exploitation que vous utilisez, vous pouvez accéder au serveur IP

Comment vérifier la version nginx Comment vérifier la version nginx Apr 14, 2025 am 11:57 AM

Les méthodes qui peuvent interroger la version Nginx sont: utilisez la commande nginx -v; Afficher la directive de version dans le fichier nginx.conf; Ouvrez la page d'erreur Nginx et affichez le titre de la page.

Comment vérifier si Nginx est démarré Comment vérifier si Nginx est démarré Apr 14, 2025 pm 01:03 PM

Comment confirmer si Nginx est démarré: 1. Utilisez la ligne de commande: SystemCTl Status Nginx (Linux / Unix), netStat -ano | Findstr 80 (Windows); 2. Vérifiez si le port 80 est ouvert; 3. Vérifiez le message de démarrage NGINX dans le journal système; 4. Utilisez des outils tiers, tels que Nagios, Zabbix et Icinga.

Comment vérifier le nom du conteneur Docker Comment vérifier le nom du conteneur Docker Apr 15, 2025 pm 12:21 PM

Vous pouvez interroger le nom du conteneur Docker en suivant les étapes: répertorier tous les conteneurs (Docker PS). Filtrez la liste des conteneurs (à l'aide de la commande grep). Obtient le nom du conteneur (situé dans la colonne "Noms").

Comment exécuter nginx apache Comment exécuter nginx apache Apr 14, 2025 pm 12:33 PM

Pour faire en sorte que Nginx exécute Apache, vous devez: 1. Installez Nginx et Apache; 2. Configurer l'agent Nginx; 3. Démarrer Nginx et Apache; 4. Testez la configuration pour vous assurer que vous pouvez voir le contenu Apache après avoir accédé au nom de domaine. De plus, vous devez faire attention à d'autres questions telles que la correspondance du numéro de port, la configuration de l'hôte virtuel et les paramètres SSL / TLS.

Comment créer un miroir dans Docker Comment créer un miroir dans Docker Apr 15, 2025 am 11:27 AM

Étapes pour créer une image docker: écrivez un dockerfile qui contient les instructions de construction. Créez l'image dans le terminal, en utilisant la commande docker build. Marquez l'image et attribuez des noms et des balises à l'aide de la commande docker tag.

Comment démarrer un conteneur par Docker Comment démarrer un conteneur par Docker Apr 15, 2025 pm 12:27 PM

Étapes de démarrage du conteneur Docker: Tirez l'image du conteneur: Exécutez "Docker Pull [Mirror Name]". Créer un conteneur: utilisez "Docker Create [Options] [Mirror Name] [Commandes et paramètres]". Démarrez le conteneur: exécutez "docker start [nom de conteneur ou id]". Vérifiez l'état du conteneur: vérifiez que le conteneur s'exécute avec "Docker PS".

See all articles