


Comment utiliser Nginx pour le proxy inverse et l'équilibrage de charge
Comment utiliser Nginx pour le proxy inverse et l'équilibrage de charge
Introduction :
Nginx est un serveur Web open source hautes performances et un serveur proxy inverse. Il peut non seulement fournir des services de fichiers statiques comme un serveur Web traditionnel, mais également servir de serveur proxy inverse, transmettant les demandes des clients à plusieurs serveurs principaux et réalisant l'équilibrage de charge. Cet article explique comment utiliser Nginx pour implémenter la configuration du proxy inverse et de l'équilibrage de charge.
1. Proxy inverse
Le proxy inverse signifie que le serveur Web reçoit la demande du client et la transmet à plusieurs serveurs back-end. Le client ne peut pas établir de connexion directement avec le serveur back-end et ne peut communiquer avec le serveur back-end que via le serveur proxy inverse. Le proxy inverse peut masquer la véritable adresse IP du serveur backend et améliorer la sécurité du système.
Exemple de configuration :
Dans le fichier de configuration Nginx, ajoutez un nouveau bloc serveur pour configurer le proxy inverse :
server { listen 80; server_name example.com; location / { proxy_pass http://backend_servers; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } }
Dans la configuration ci-dessus, listening spécifie le port sur lequel Nginx écoute et server_name spécifie le nom de domaine du proxy inverse. location / signifie transmettre toutes les demandes au serveur backend. proxy_pass configure l'adresse du serveur backend, qui peut être une adresse IP ou un nom de domaine. proxy_set_header peut définir certaines informations d'en-tête HTTP, telles que Host et X-Real-IP, etc.
2. Équilibrage de charge
L'équilibrage de charge fait référence à la distribution des requêtes à plusieurs serveurs principaux pour améliorer les performances et la disponibilité du système. Nginx prend en charge une variété d'algorithmes d'équilibrage de charge, tels que l'interrogation, l'interrogation pondérée, les moindres connexions, etc.
Exemple de configuration :
Dans le fichier de configuration Nginx, ajoutez un nouveau bloc en amont pour configurer le serveur backend :
upstream backend_servers { server 192.168.0.1:8080; server 192.168.0.2:8080; server 192.168.0.3:8080; server 192.168.0.4:8080; } server { listen 80; server_name example.com; location / { proxy_pass http://backend_servers; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } }
Dans la configuration ci-dessus, le bloc en amont définit les adresses et les ports de plusieurs serveurs backend. Dans le bloc d'emplacement, proxy_pass configure le nom du bloc en amont et Nginx sélectionnera le serveur backend approprié en fonction de l'algorithme d'équilibrage de charge configuré.
3. Implémenter le contrôle de santé
Afin de garantir la disponibilité du serveur backend, vous pouvez ajouter la fonction de contrôle de santé lorsque le serveur backend tombe en panne, Nginx transmettra automatiquement la demande à d'autres serveurs normaux.
Exemple de configuration :
Dans le fichier de configuration Nginx, vous pouvez ajouter un nouveau bloc d'emplacement pour implémenter la vérification de l'état :
location /check { access_log off; proxy_pass http://backend_servers; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504; }
Dans la configuration ci-dessus, location /check signifie que lorsque l'accès à /check est demandé, Nginx transmettra la demande à le serveur principal et vérifiez le code d'état qu'il renvoie. Si le code d'état renvoyé est error, timeout, invalid_header, http_500, http_502, http_503 ou http_504, Nginx transmettra la demande à d'autres serveurs normaux.
Conclusion :
En utilisant les capacités de proxy inverse et d'équilibrage de charge de Nginx, les performances et la disponibilité de votre système peuvent être améliorées. Grâce à l'introduction et aux exemples de code de cet article, je pense que les lecteurs ont compris comment configurer Nginx pour le proxy inverse et l'équilibrage de charge. J'espère que cela sera utile aux lecteurs dans la pratique.
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

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.

Dans Linux, utilisez la commande suivante pour vérifier si Nginx est démarré: SystemCTL Status Nginx Juges Basé sur la sortie de la commande: si "Active: Active (Running)" s'affiche, Nginx est démarré. Si "Active: Inactive (Dead)" est affiché, Nginx est arrêté.

Étapes pour démarrer Nginx dans Linux: Vérifiez si Nginx est installé. Utilisez SystemCTL Start Nginx pour démarrer le service NGINX. Utilisez SystemCTL Activer Nginx pour activer le démarrage automatique de Nginx au démarrage du système. Utilisez SystemCTL Status Nginx pour vérifier que le démarrage est réussi. Visitez http: // localhost dans un navigateur Web pour afficher la page de bienvenue par défaut.

Comment configurer Nginx dans Windows? Installez Nginx et créez une configuration d'hôte virtuelle. Modifiez le fichier de configuration principale et incluez la configuration de l'hôte virtuel. Démarrer ou recharger nginx. Testez la configuration et affichez le site Web. Activer sélectivement SSL et configurer les certificats SSL. Définissez sélectivement le pare-feu pour permettre le trafic Port 80 et 443.

Comment corriger l'erreur interdite Nginx 403? Vérifier les autorisations de fichier ou de répertoire; 2. Vérifier le fichier .htaccess; 3. Vérifiez le fichier de configuration NGINX; 4. Redémarrer Nginx. D'autres causes possibles incluent les règles de pare-feu, les paramètres de Selinux ou les problèmes d'application.

Les méthodes pour afficher l'état en cours d'exécution de Nginx sont: utilisez la commande PS pour afficher l'état du processus; Afficher le fichier de configuration Nginx /etc/nginx/nginx.conf; Utilisez le module d'état NGINX pour activer le point de terminaison d'état; Utilisez des outils de surveillance tels que Prometheus, Zabbix ou Nagios.

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

Il existe deux façons de résoudre le problème du domaine transversal NGINX: modifiez les en-têtes de réponse transversale: ajoutez des directives pour autoriser les demandes de domaine croisé, spécifier des méthodes et des en-têtes autorisés et définir le temps du cache. Utilisez le module CORS: Activez les modules et configurez les règles CORS pour permettre des demandes, des méthodes, des en-têtes et du temps de cache.
