Maison Opération et maintenance Nginx Comment atteindre la haute disponibilité de Nginx

Comment atteindre la haute disponibilité de Nginx

May 25, 2023 pm 11:31 PM
nginx

Préparation :

192.168.16.128

192.168.16.129

Deux machines virtuelles. Installez Nginx

Installez Nginx

Mettre à jour le fichier source miam :

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

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

Installez Nginx :

miam -y installe nginx

Commande d'opération :

systemctl démarre nginx ; #Démarrer Nginx

systemctl arrête nginx ; #Arrêtez Nginx

Qu’est-ce que la haute disponibilité ?

La haute disponibilité HA (High Availability) 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é le VRRP (Virtual Router Redundancy Protocol) pour obtenir une fonction de 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 envoie en permanence des messages de battement de cœur (multidiffusion) au nœud de sauvegarde pour indiquer au nœud de sauvegarde qu'il est toujours en vie. Lorsque le nœud maître tombe en panne, il ne peut pas envoyer de messages de battement de cœur et le nœud de sauvegarde le fera. ne peut 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 panne 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 -y installez keepalived

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 :

vi keepalived.conf

keepalived.conf:

#Script de détection

vrrp_script chk_http_port {

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

intervalle 2 intervalle 2 #(Intervalle pour détecter l'exécution du script, l'unité est la seconde)

poids 2 }

#vrrp Section de définition d'instance

vrrp_instance VI_1 {

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

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

Virtual_router_id 66 # Le numéro de route virtuelle, le maître et l'esclave doivent toujours être les mêmes

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

advert_int 1             # Intervalle de vérification, la valeur par défaut est de 1 s (secondes du cycle de multidiffusion vrrp)

#accèsautorisé

authentification {

auth_type PASS #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_pass 1111

}

track_script {

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

}

Adresse_ip_virtuelle {

192.168.16.130 192.168.16.130 # Définissez 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 ip addr

. 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_script chk_http_port {

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

intervalle 2 intervalle 2 #(Intervalle pour détecter l'exécution du script)

poids 2 }

#vrrp Section de définition d'instance

vrrp_instance VI_1 {

state BACKUP # Spécifie le rôle de keepalived, MASTER est le rôle principal et BACKUP est celui de sauvegarde interface ens33 # La carte d'interface réseau actuelle pour la communication vrrp (carte réseau centos actuelle) Utilisez ifconfig pour vérifier votre carte réseau spécifique

virtual_router_id 66 # Le numéro de route virtuelle, le maître et l'esclave doivent toujours être les mêmes priorité 99                                                                                                                                                                                                                                                                                                        annonce_int 1 #accèsautorisé

authentification {

auth_type PASS #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_pass 1111

}

track_script {

chk_http_port }

Adresse_ip_virtuelle {

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

}

}

Script de détection :

#!/bin/bash

#Vérifiez si nginx est démarré

A=`ps -C nginx --no-header |wc -l`

if [ $A -eq 0 ];then #Si nginx n'est pas démarré, démarrez nginx systemctl démarre nginx #Redémarrer nginx

Si [ `ps -C nginx --no-header |wc -l` -eq 0 ]; alors #nginx ne parvient pas à redémarrer, arrêtez le service keepalived et effectuez un transfert VIP

                                          killall keepalived                                                           fi

fi

Autorisation du script : chmod 775 check_nginx_pid.sh

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

Simuler un échec nginx :

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

Accédez d'abord au 192.168.16.130 et accédez-y 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 :

systemctl arrête nginx ; #Arrêtez nginx

Visitez à nouveau VIP (192.168.16.130) et constatez que la page affiche toujours : 192.168.16.128. Il s'agit 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.

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 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 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 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 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 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".

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 configurer Nginx dans Windows Comment configurer Nginx dans Windows Apr 14, 2025 pm 12:57 PM

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.

See all articles