suchen
HeimBetrieb und InstandhaltungNginxSo erreichen Sie eine hohe Verfügbarkeit von Keepalived + Nginx

1.Keepalived-Einführung

keepalived wurde ursprünglich für die LVS-Lastausgleichssoftware entwickelt, um den Status jedes Dienstknotens im LVS-Clustersystem zu verwalten und zu überwachen. Später wurde die VRRP-Funktion für Hochverfügbarkeit hinzugefügt. Neben der Verwaltung der LVS-Software kann keepalived auch Hochverfügbarkeitslösungen für andere Dienste unterstützen.

keepalived implementiert die Hochverfügbarkeitsfunktion über das VRRP-Protokoll. vrrp (Virtual Router Redundancy Protocol) Redundanzprotokoll für virtuelle Router. Der Zweck von vrrp besteht darin, das Single-Point-of-Failure-Problem des statischen Routings zu lösen. Es kann sicherstellen, dass beim Ausfall einzelner Knoten das gesamte Netzwerk unterbrechungsfrei laufen kann.

2. Keepalived-Hochverfügbarkeits-Failover-Prinzip

Failover zwischen Keepalived-Hochverfügbarkeitsdiensten wird über vrrp implementiert. Wenn der Keepalived-Dienst funktioniert, sendet der Masterknoten kontinuierlich (Multicast-)Heartbeat-Nachrichten an den Backup-Knoten, um dem Backup-Knoten mitzuteilen, dass er noch aktiv ist.

 Wenn der Master-Knoten ausfällt, können keine Heartbeat-Nachrichten an den Backup-Knoten gesendet werden, wenn der Backup-Knoten den Heartbeat vom Master-Knoten nicht weiterhin erkennen kann. Es ruft sein eigenes Übernahmeprogramm auf, um die IP-Ressourcen und -Dienste des Masterknotens zu übernehmen. Wenn der Primärknoten wiederhergestellt ist, gibt der Standby-Knoten die IP-Ressourcen und Dienste frei, die er übernommen hat, als der Primärknoten ausgefallen ist, und kehrt zu seiner ursprünglichen Standby-Rolle zurück

3. Installieren Sie nginx

3.1. 80.22)

3.1.1. Kompilierungstools und Bibliotheksdateien installieren

yum -y install make zlib zlib-devel gcc-c++ libtool openssl openssl-devel

3.1.3. Nginx installieren

#进入目录
cd /usr/local/develop/anginx

#上传安装文件并解压
tar -zxvf pcre-8.38.tar.gz

#进入安装目录
cd pcre-8.38

#检查配置
./configure

#编译、安装
make && make install

#查看pcre版本
pcre-config --version

#进入目录
cd /usr/local/develop/anginx

#上传安装文件,并解压
tar -zxvf nginx-1.8.1.tar.gz

#进入安装目录
cd nginx-1.8.1

#检查配置
./configure --prefix=/usr/local/develop/anginx/webserver/nginx --with-http_stub_status_module --with-http_ssl_module --with-pcre=/usr/local/develop/anginx/pcre-8.38

#编译安装
make && make install

#查看nginx版本
 /usr/local/develop/anginx/webserver/nginx/sbin/nginx -v
--------------------------------------------------------
[root@hadoop02 webserver]# /usr/local/develop/anginx/webserver/nginx/sbin/nginx -v
nginx version: nginx/1.8.1

#配置nginx(检查)
/usr/local/develop/anginx/webserver/nginx/sbin/nginx -t

#nginx管理命令
/usr/local/develop/anginx/webserver/nginx/sbin/nginx       # 启动 nginx
/usr/local/develop/anginx/webserver/nginx/sbin/nginx -s stop       # 停止 nginx
/usr/local/develop/anginx/webserver/nginx/sbin/nginx -s reload      # 重新载入配置文件
/usr/local/develop/anginx/webserver/nginx/sbin/nginx -s reopen      # 重启 nginx

3. 2. Standby Knoten (192.168.80.21)

Hinweis: Die Installationsmethode ist die gleiche wie beim Nginx-Masterknoten. 4. Installieren Sie keepalived

【vrrp_instance vi_1】{...} Dies ist eine vrrp-Instanz, die den aktiven und Sicherungsstatus, die Schnittstelle, die Priorität, die Authentifizierung und die IP-Informationen von keepalived definiert.

[Status] definiert die Rolle von vrrp

[Schnittstelle] definiert die von meinem Server verwendete Schnittstelle eth1

    [virtual_router_id] ist die ID des virtuellen Routers. In einer Reihe von Keepalived-Konfigurationen sind die Haupt- und Backup-Einstellungen konsistent
  • [priority] ist die Priorität, je größer die Zahl, desto höher die Priorität,

    • [auth_type] ist die Authentifizierungsmethode

    • [auth_pass] ist das Passwort für die Authentifizierung

    • [virtual_ipaddress] {...}Definition der virtuellen IP-Adresse, mehrere IP-Adressen können konfiguriert werden, hier definiere ich sie als 192.168.80.100, die an die Netzwerkschnittstelle von eth1 gebunden ist, virtuelle Schnittstelle eth1:1

    • 4.2. Standby Knoten (192.168.80.21)
    • vi nginx.conf
      
      #user nobody;
      worker_processes 1;
      
      #error_log logs/error.log;
      #error_log logs/error.log notice;
      #error_log logs/error.log info;
      
      pid    logs/nginx.pid;
      
      
      events {
        worker_connections 1024;
      }
      
      
      http {
        include    mime.types;
        default_type application/octet-stream;
      
        log_format main '$remote_addr - $remote_user [$time_local] "$request" '
                 '$status $body_bytes_sent "$http_referer" '
                 '"$http_user_agent" "$http_x_forwarded_for"';
      
        access_log logs/access.log main;
      
        sendfile    on;
        #tcp_nopush   on;
      
        #keepalive_timeout 0;
        keepalive_timeout 65;
      
        #gzip on;
        
        #添加tomcat列表,真实应用服务器都放在这
        upstream tomcat_pool{
          #server tomcat地址:端口号 weight表示权值,权值越大,被分配的几率越大;
          server 192.168.80.22:8080 weight=4 max_fails=2 fail_timeout=30s;
          server 192.168.80.22:8081 weight=4 max_fails=2 fail_timeout=30s;
          
        }
      
        server {
          listen    80;
          server_name tomcat_pool;
      
          #charset koi8-r;
      
          #access_log logs/host.access.log main;
      
          location / {
            #root  html;
            #index index.html index.htm;
            proxy_pass http://tomcat_pool;  #转向tomcat处理
            proxy_set_header  host       $host;
            proxy_set_header  x-real-ip    $remote_addr;
            proxy_set_header  x-forwarded-for $proxy_add_x_forwarded_for;
          }
      
          #error_page 404       /404.html;
      
          # redirect server error pages to the static page /50x.html
          #
          error_page  500 502 503 504 /50x.html;
          location = /50x.html {
            root  html;
          }
      
      
      }

      5. Testen Sie 5.1. Starten Sie den Keepalived-Dienst der aktiven und Backup-Knoten. 192.168.80.100/session-redis-demo/
    • 5.3. Stoppen Sie den Master-Knoten-Keepalive-Dienst
    • #安装keepalived
      yum install keepalived -y
      
      #启动keepalived服务
      /etc/init.d/keepalived start
      -------------------------------------------
      [root@hadoop02 anginx]# /etc/init.d/keepalived start
      正在启动 keepalived:                   [确定]
      [root@hadoop02 anginx]# ps -ef |grep keepalived
      root   15723   1 0 00:59 ?    00:00:00 /usr/sbin/keepalived -d
      root   15724 15723 0 00:59 ?    00:00:00 /usr/sbin/keepalived -d
      root   15725 15723 0 00:59 ?    00:00:00 /usr/sbin/keepalived -d
      root   15731 15622 0 00:59 pts/1  00:00:00 grep keepalived
      [root@hadoop02 anginx]#
      
      #设置开机自启动
      echo "/etc/init.d/keepalived start" >>/etc/rc.local
      
      #关闭keepalived服务
      /etc/init.d/keepalived stop
      
      #编辑keepalived配置文件
      vi /etc/keepalived/keepalived.conf
      
      -----------------------------------------------------------
      ! configuration file for keepalived
      
      global_defs {
        notification_email {
         acassen@firewall.loc
         failover@firewall.loc
         sysadmin@firewall.loc
        }
        notification_email_from alexandre.cassen@firewall.loc
        smtp_server 192.168.200.1
        smtp_connect_timeout 30
        router_id lb01
      }
      
      vrrp_instance vi_1 {
        state master
        interface eth1
        virtual_router_id 55
        priority 150
        advert_int 1
        authentication {
          auth_type pass
          auth_pass server123
        }
        virtual_ipaddress {
          192.168.80.100 dev eth1 label eth1:1
        }
      }
      ...........................................................

      5.4. Greifen Sie weiterhin über die virtuelle IP auf den Dienst zu
  • http://192.168.80.100/session- redis-demo/

6.keepalived+nginx-Integration

Anweisungen: Schreiben Sie ein Nginx-Daemon-Skript, um den Keepalived-Dienst des aktuellen Knotens zu stoppen, wenn der Nginx-Dienst ausfällt. Wechselt automatisch zum Backup-Knoten.

6.1. Schreiben Sie ein Nginx-Daemon-Skript

Das obige ist der detaillierte Inhalt vonSo erreichen Sie eine hohe Verfügbarkeit von Keepalived + Nginx. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Dieser Artikel ist reproduziert unter:亿速云. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen
Der ultimative Showdown: Nginx vs. ApacheDer ultimative Showdown: Nginx vs. ApacheApr 18, 2025 am 12:02 AM

Nginx eignet sich zum Umgang mit hohen gleichzeitigen Anforderungen, während Apache für Szenarien geeignet ist, in denen komplexe Konfigurationen und funktionale Erweiterungen erforderlich sind. 1.Nginx nimmt eine ereignisorientierte, nicht blockierende Architektur an und eignet sich für Umgebungen mit hoher Konsequenz. 2. Apache übernimmt Prozess- oder Threadmodell, um ein reiches Modul -Ökosystem bereitzustellen, das für komplexe Konfigurationsanforderungen geeignet ist.

Nginx in Aktion: Beispiele und reale AnwendungenNginx in Aktion: Beispiele und reale AnwendungenApr 17, 2025 am 12:18 AM

NGINX kann verwendet werden, um die Leistung, Sicherheit und Skalierbarkeit der Website zu verbessern. 1) Als Reverse Proxy und Load Balancer kann Nginx Back-End-Dienste optimieren und den Verkehr teilen. 2) Durch ereignisgesteuerte und asynchrone Architektur verarbeitet Nginx effizient hohe gleichzeitige Verbindungen. 3) Konfigurationsdateien ermöglichen eine flexible Definition von Regeln wie statischer Dateiservice und Ladeausgleich. 4) Optimierungsvorschläge umfassen die Aktivierung der GZIP -Komprimierung, die Verwendung von Cache und das Einstellen des Arbeitsprozesses.

Nginx -Einheit: Unterstützung verschiedener ProgrammiersprachenNginx -Einheit: Unterstützung verschiedener ProgrammiersprachenApr 16, 2025 am 12:15 AM

NginxUnit unterstützt mehrere Programmiersprachen und wird durch modulares Design implementiert. 1. Ladesprachmodul: Laden Sie das entsprechende Modul gemäß der Konfigurationsdatei. 2. Anwendungsstart: Führen Sie den Anwendungscode aus, wenn die aufrufende Sprache ausgeführt wird. 3. Anforderungsverarbeitung: Leiten Sie die Anfrage an die Anwendungsinstanz weiter. 4. Antwortrückgabe: Gibt die verarbeitete Antwort an den Client zurück.

Wählen Sie zwischen Nginx und Apache: Die richtige Passform für Ihre AnforderungenWählen Sie zwischen Nginx und Apache: Die richtige Passform für Ihre AnforderungenApr 15, 2025 am 12:04 AM

Nginx und Apache haben ihre eigenen Vor- und Nachteile und eignen sich für verschiedene Szenarien. 1.Nginx ist für hohe Parallelitäts- und geringe Ressourcenverbrauchsszenarien geeignet. 2. Apache eignet sich für Szenarien, in denen komplexe Konfigurationen und reichhaltige Module erforderlich sind. Durch den Vergleich ihrer Kernfunktionen, Leistungsunterschiede und Best Practices können Sie die Serversoftware auswählen, die Ihren Anforderungen am besten entspricht.

So starten Sie NginxSo starten Sie NginxApr 14, 2025 pm 01:06 PM

Frage: Wie starte ich Nginx? Antwort: Installieren Sie Nginx Startup Nginx -Verifizierung Nginx Is Nginx Start Erkunden

So überprüfen Sie, ob Nginx gestartet wirdSo überprüfen Sie, ob Nginx gestartet wirdApr 14, 2025 pm 01:03 PM

So bestätigen Sie, ob Nginx gestartet wird: 1. Verwenden Sie die Befehlszeile: SystemCTL Status Nginx (Linux/Unix), Netstat -ano | FindStr 80 (Windows); 2. Überprüfen Sie, ob Port 80 geöffnet ist; 3. Überprüfen Sie die Nginx -Startmeldung im Systemprotokoll. 4. Verwenden Sie Tools von Drittanbietern wie Nagios, Zabbix und Icinga.

Wie man nginx schließtWie man nginx schließtApr 14, 2025 pm 01:00 PM

To shut down the Nginx service, follow these steps: Determine the installation type: Red Hat/CentOS (systemctl status nginx) or Debian/Ubuntu (service nginx status) Stop the service: Red Hat/CentOS (systemctl stop nginx) or Debian/Ubuntu (service nginx stop) Disable automatic startup (optional): Red Hat/CentOS (systemctl disabled nginx) or Debian/Ubuntu (syst

So konfigurieren Sie Nginx in WindowsSo konfigurieren Sie Nginx in WindowsApr 14, 2025 pm 12:57 PM

Wie konfiguriere ich Nginx in Windows? Installieren Sie NGINX und erstellen Sie eine virtuelle Hostkonfiguration. Ändern Sie die Hauptkonfigurationsdatei und geben Sie die Konfiguration der virtuellen Host ein. Starten oder laden Nginx neu. Testen Sie die Konfiguration und sehen Sie sich die Website an. Aktivieren Sie selektiv SSL und konfigurieren Sie SSL -Zertifikate. Stellen Sie die Firewall selektiv fest, damit Port 80 und 443 Verkehr.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Crossplay haben?
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

WebStorm-Mac-Version

WebStorm-Mac-Version

Nützliche JavaScript-Entwicklungstools

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

Sicherer Prüfungsbrowser

Sicherer Prüfungsbrowser

Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.