Maison >Opération et maintenance >Nginx >Le module géo dans Nginx et comment l'utiliser pour configurer l'équilibrage de charge
La directive geo est fournie par le module ngx_http_geo_module. Par défaut, nginx charge ce module sauf si --without-http_geo_module est configuré manuellement. Le module
ngx_http_geo_module peut être utilisé pour créer des variables dont les valeurs dépendent de l'adresse IP du client.
commande geo
Syntaxe : geo [$address] $variable { ... }
Valeur par défaut : —
Section de configuration : http
Définition pour obtenir l'adresse IP du client à partir de la variable spécifiée. Par défaut, nginx obtient l'adresse IP du client à partir de la variable $remote_addr, mais elle peut également être obtenue à partir d'autres variables. Tel que
geo $remote_addr $geo { default 0; 127.0.0.1 1; } geo $arg_ttlsa_com $geo { default 0; 127.0.0.1 1; }
Si la valeur de cette variable ne représente pas une adresse IP légale, alors nginx utilisera l'adresse "255.255.255.255".
nginx décrit l'adresse via cidr ou segment d'adresse et prend en charge les paramètres suivants :
delete : supprime le réseau spécifié
Si l'adresse client ne peut correspondre à aucune adresse définie, nginx utilisera la valeur par défaut. CIDR peut utiliser « 0.0.0.0/0 » pour remplacer la valeur par défaut.
include : contient un fichier qui définit des adresses et des valeurs, et peut en contenir plusieurs.
proxy : définissez des adresses de confiance. Lorsque la requête provient d'une adresse fiable, nginx obtiendra les informations d'adresse à l'aide de son en-tête « X-Forwarded-For ». Par rapport aux adresses ordinaires, les adresses fiables sont détectées de manière séquentielle.
proxy_recursive : Activer la recherche d'adresse récursive. Si la recherche récursive est désactivée, nginx utilisera la dernière adresse dans « x-forwarded-for » au lieu de l'adresse client d'origine lorsque l'adresse client correspond à une adresse fiable. Si la recherche récursive est activée, lorsque l'adresse du client correspond à une adresse de confiance, nginx utilisera la dernière adresse de "x-forwarded-for" qui ne correspond à aucune adresse de confiance pour remplacer l'adresse du client d'origine.
ranges : Définissez l'adresse sous la forme d'un segment d'adresse. Ce paramètre doit être placé en premier. Pour accélérer le chargement de la bibliothèque d'adresses, les adresses doivent être définies par ordre croissant.
geo $country { default zz; include conf/geo.conf; delete 127.0.0.0/16; proxy 192.168.100.0/24; proxy 2001:0db8::/32; 127.0.0.0/24 us; 127.0.0.1/32 ru; 10.1.0.0/16 ru; 192.168.1.0/24 uk; }
vim conf/geo.conf
10.2.0.0/16 ru; 192.168.2.0/24 ru;
Exemple de segment d'adresse :
geo $country { ranges; default zz; 127.0.0.0-127.0.0.0 us; 127.0.0.1-127.0.0.1 ru; 127.0.0.1-127.0.0.255 us; 10.1.0.0-10.1.255.255 ru; 192.168.1.0-192.168.1.255 uk; }
La commande geo attribue principalement des valeurs aux variables en fonction de l'IP. Par conséquent, seuls les segments IP ou réseau peuvent être définis sous le bloc géographique, sinon une erreur sera signalée.
le module géo implémente l'équilibrage de charge global
server1 : 192.168.6.101
server2 : 192.168.6.102
server3 : 192.168.6.121
Test machine 1 ip : 192.168.6.2
T est la machine 2 ip : 192.168.6.8
Test de la machine 3 ip : 192.168.6.189
1. Compilez et installez nginx sur chaque serveur, je n'en dirai pas plus !
Je n'ai pas modifié les configurations du serveur1 et du serveur2~ J'ai seulement changé leur page d'accueil, ce qui est utile pour les tests !
server1:
shell $> cd /usr/local/nginx/html shell $> rm index.html shell $> echo "192.168.6.101" > index.html
server2:
shell $> cd /usr/local/nginx/html shell $> rm index.html shell $> echo "192.168.6.102" > index.html
Up their services
shell $> /usr/local/nginx/sbin/nginx
2 Modifier la configuration du serveur3`
shell $> cd /usr/local/nginx/conf/ shell $> vim nginx.conf
worker_processes 1; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; geo $geo { default default; 192.168.6.189/32 uk; 192.168.6.8/32 us; #这里的子网码是 32 是因为,我是单网段测试,如果你有vlan,你可以是24 例如 # 192.168.0.0/24 tw } upstream uk.server { server 192.168.6.101; } upstream us.server { server 192.168.6.102; } upstream default.server { server 192.168.6.121:8080; } sendfile on; keepalive_timeout 65; server { listen 80; server_name 192.168.6.121; index index.html index.htm; root html; location / { proxy_redirect off; 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_pass http://$geo.server$request_uri; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } server { listen 8080; server_name 192.168.6.121; location / { root html; index index.html index.htm; } } }
3.
http://192.168.6.121
et il affichera
Parce que l'adresse IP de la machine de test 1 est 192.168.6.2 D'après la configuration de nginx, il est évident qu'il accède au port 8080 du serveur 3 ! Parce que j'ai modifié l'index.html du serveur1 serveur2
Ouvrez le navigateur sur la machine de test 2 ~ entrez
http://192.168.6.121
Afficher
Ouvrez le navigateur sur la machine de test 3 ~ entrez
http :/ /192.168.6.121
L'adresse IP de la machine de test 3 est 192.168.6.189
Affichage :
Évidemment, l'équilibrage de charge joue un rôle~~~
De cette façon, les trois serveurs peuvent être placés dans différentes salles informatiques IDC . Ensuite, synchronisez simplement les données ~ L'avantage est que cela évite les problèmes avec le DNS, car le DNS intelligent analysera parfois l'adresse DNS de l'autre partie lors de l'analyse en fonction de l'adresse IP de la visite et la fera correspondre à un serveur si l'autre partie est là. est un utilisateur Netcom. Le DNS Telecom qu'il utilise le fera directement correspondre au serveur Telecom, nginx, et correspondra au serveur en fonction de l'IP d'accès. De cette façon, tant que nous collectons les segments IP de chaque région, ce sera le cas. bien
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!