Maison >Opération et maintenance >Nginx >Méthode de haute disponibilité Nginx

Méthode de haute disponibilité Nginx

WBOY
WBOYavant
2023-05-31 15:04:061492parcourir

Travail de préparation :

Méthode de haute disponibilité Nginx

​192.168.16.128

​192.168.16.129

Deux machines virtuelles. Installez Nginx

​Installez Nginx

Mettre à jour le fichier source miam :

rpm-ivhhttp://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm

wget-O/etc/yum.repos.d/CentOS-Base.repohttp://mirrors.aliyun.com/repo/Centos-7.repo

​Installez Nginx :

​ miam-yinstallnginx

Commande d'opération :

systemctlstartnginx;#Démarrer Nginx

systemctlstopnginx;#stopNginx

Qu’est-ce que la haute disponibilité ?

La haute disponibilité HA (HighAvailability) est l'un des facteurs à prendre en compte dans la conception d'une architecture de système distribué. Elle fait généralement référence à la réduction du temps pendant lequel le système ne peut pas fournir de services grâce à la conception. Si un système peut toujours fournir des services, alors la disponibilité est de 100 %, mais il existe des circonstances imprévues. Nous ne pouvons donc qu’essayer de réduire autant que possible les pannes de service.

Problème résolu ?

Dans les environnements de production, Nginx est souvent utilisé comme proxy inverse pour fournir des services externes. Cependant, Nginx rencontrera inévitablement un jour des pannes, comme une indisponibilité du serveur. Lorsque Nginx tombe en panne, toutes les interfaces fournies en externe deviendront inaccessibles.

Bien que nous ne puissions pas garantir que le serveur soit disponible à 100%, nous devons trouver un moyen d'éviter cette tragédie. Aujourd'hui, nous utilisons keepalived pour implémenter Nginx

. Haute disponibilité.

Solution de sauvegarde à chaud sur deux machines

Cette solution est la solution de haute disponibilité la plus courante parmi les entreprises nationales. La sauvegarde à chaud sur deux serveurs signifie en fait qu'un serveur fournit des services et que l'autre est en veille pour un certain service. Lorsqu'un serveur est indisponible, l'autre le prendra. sa place.

Qu'est-ce qu'un keepalived ?

Le logiciel Keepalived a été initialement conçu pour le logiciel d'équilibrage de charge LVS afin de gérer et de surveiller l'état de chaque nœud de service dans le système de cluster LVS. Plus tard, il a ajouté la fonction VRRP (Virtual Router Redundancy Protocol) qui peut atteindre une haute disponibilité. Par conséquent, en plus de gérer le logiciel LVS, Keepalived peut également être utilisé comme solution logicielle à haute disponibilité pour d'autres services (tels que Nginx, Haproxy, MySQL, etc.)

Mécanisme de basculement

Le transfert de basculement entre les services haute disponibilité Keepalived est mis en œuvre via VRRP.

Lorsque le service Keepalived fonctionne normalement, le nœud maître principal envoie en permanence des messages de battement de cœur (multidiffusion) au nœud de sauvegarde pour indiquer au nœud de sauvegarde de sauvegarde qu'il est toujours en vie. Lorsque le nœud maître principal tombe en panne, il ne peut pas envoyer de messages de battement de cœur et le nœud de sauvegarde. Le nœud de sauvegarde ne pourra pas envoyer de messages de battement de cœur. Par conséquent, le nœud ne peut plus détecter le battement de cœur du nœud maître principal, il appelle donc son propre programme de reprise pour prendre en charge les ressources et services IP du nœud maître principal. Lorsque le nœud maître récupère, le nœud de sauvegarde libère les ressources IP et les services qu'il avait pris en charge lors de la défaillance du nœud maître et reprend son rôle de sauvegarde d'origine.

Processus de mise en œuvre

​Installez keepalived

Vous pouvez l'installer directement en utilisant yum, qui installera automatiquement les dépendances :

​ miam-yinstallkeepalived

Modifier le fichier de configuration keepalived de l'hôte (192.168.16.128)

L'installation avec yum produira le fichier de configuration sous /etc/keepalived :

vikeepalived.conf

keepalived.conf:

​ #Script de détection

vrrp_scriptchk_http_port{

​script"/usr/local/src/check_nginx_pid.sh"#Script d'exécution Heartbeat pour détecter si nginx est démarré

interval2# (intervalle de détection de l'exécution du script, l'unité est la seconde)

poids2# poids

}

​ Partie de définition d'instance #vrrp

vrrp_instanceVI_1{

stateMASTER#Spécifiez le rôle de keepalived, MASTER est le rôle principal et BACKUP est celui de sauvegarde

interfaceens33#La carte d'interface réseau actuelle pour la communication vrrp (carte réseau centos actuelle) utilise ifconfig pour vérifier votre carte réseau spécifique

​virtual_router_id66#Numéro de route virtuelle, le maître et l'esclave doivent toujours

priorité100#Priorité, plus la valeur est grande, plus la priorité d'obtention et de traitement de la demande est élevée

advert_int1# Vérifier l'intervalle, la valeur par défaut est de 1 s (secondes du cycle de multidiffusion vrrp)

​ #AccèsAutorisé

Authentification{

auth_typePASS#Définissez le type de vérification et le mot de passe MASTER et BACKUP doivent utiliser le même mot de passe pour une communication normale

. auth_pass1111

}

track_script{

chk_http_port# (script de détection d'appel)

}

adresse_ip_virtuelle{

​192.168.16.130#Définir une adresse IP virtuelle (VIP), vous pouvez en définir plusieurs, une par ligne

}

}

VIP peut être configuré dans virtual_ipaddress et les services sont accessibles en ligne via VIP.

L'interface doit être définie en fonction de la carte réseau du serveur. La méthode de visualisation habituelle est ipaddr

. L'accès à l'autorisation de configuration de l'authentification à la machine de sauvegarde nécessite également la même configuration

Modifier le fichier de configuration keepalived de la machine de sauvegarde (192.168.16.129)

keepalived.conf:

​ #Script de détection

vrrp_scriptchk_http_port{

​script"/usr/local/src/check_nginx_pid.sh"#Script d'exécution Heartbeat pour détecter si nginx est démarré

interval2# (intervalle d'exécution du script de détection)

poids2# poids

}

​ Partie de définition d'instance #vrrp

vrrp_instanceVI_1{

stateBACKUP#Spécifiez le rôle de keepalived, MASTER est le rôle principal et BACKUP est celui de sauvegarde

interfaceens33#La carte d'interface réseau actuelle pour la communication vrrp (carte réseau centos actuelle) utilise ifconfig pour vérifier votre carte réseau spécifique

​virtual_router_id66#Numéro de route virtuelle, le maître et l'esclave doivent toujours

priorité99#Priorité, plus la valeur est grande, plus la priorité d'obtention et de traitement de la demande est élevée

advert_int1# Vérifier l'intervalle, la valeur par défaut est de 1 s (secondes du cycle de multidiffusion vrrp)

​ #AccèsAutorisé

Authentification{

auth_typePASS#Définissez le type de vérification et le mot de passe MASTER et BACKUP doivent utiliser le même mot de passe pour une communication normale

. auth_pass1111

}

track_script{

chk_http_port# (script de détection d'appel)

}

adresse_ip_virtuelle{

​192.168.16.130#Définir une adresse IP virtuelle (VIP), vous pouvez en définir plusieurs, une par ligne

}

}

Script de détection :

​ #!/bin/bash

​ #Détecter si nginx est démarré

A=`ps-Cnginx--no-header|wc-l`

​if[$A-eq0];then#Si nginx n'est pas démarré, démarrez nginx

systemctlstartnginx#restart nginx

​if[`ps-Cnginx--no-header|wc-l`-eq0];then#nginx ne parvient pas à redémarrer, puis arrêtez le service keepalived et effectuez un transfert VIP

killallkeepalived

Fi

Fi

Autorisation du script : chmod775check_nginx_pid.sh

Remarque : Le script doit être autorisé, sinon il n'aura pas l'autorisation d'accès. Ici, nous avons deux serveurs en cours d'exécution, VIP (virtual_ipaddress : 192.168.16.130), nous accédons au service directement via VIP dans l'environnement de production.

Simulation d'échec nginx :

Modifiez la page html Nginx à laquelle les deux serveurs accèdent par défaut par différence.

Tout d'abord, accédez au 192.168.16.130 via VIP. La page affiche 192.168.16.128, indiquant qu'il s'agit actuellement d'un service fourni par le serveur principal.

A ce moment, le serveur principal 192.168.16.128 exécute la commande :

systemctlstopnginx;#stop nginx

Lorsque j'ai de nouveau visité VIP (192.168.16.130), j'ai constaté que la page était toujours affichée : 192.168.16.128. Il s'agissait d'un redémarrage automatique dans le script.

Fermez maintenant directement le serveur 192.168.16.128, visitez VIP ici (192.168.16.130) et constatez maintenant que la page affiche 192.168.16.129. À ce moment, keepalived basculera automatiquement et constitue une solution à haute disponibilité pour une production au niveau de l'entreprise. l’environnement a été établi.

Il existe de nombreuses fonctions dans keepalived, telles que les rappels par e-mail, etc., mais elles ne sont pas disponibles. Vous pouvez accéder au site officiel pour lire la documentation.

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:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer