


Mehrere Möglichkeiten für den Nginx-Load-Balancer, die Sitzungsfreigabe zu handhaben
1) Anstatt eine Sitzung zu verwenden, verwenden Sie ein Cookie
Wenn Sie die Sitzung in ein Cookie ändern können, können Sie einige der Nachteile der Sitzung vermeiden. Ich habe dies bereits in einem J2EE-Buch gelesen , zeigt auch an, dass die Sitzung nicht in einem Clustersystem verwendet werden kann, da es sonst zu Problemen kommt und die Handhabung schwierig wird. Wenn das System nicht kompliziert ist, legen Sie Wert darauf, ob die Sitzung entfernt werden kann. Wenn das Ändern sehr schwierig ist, verwenden Sie die folgende Methode.
2) Der Anwendungsserver implementiert die Freigabe selbst
Wie bekannt ist, kann PHP eine Datenbank oder einen Memcached verwenden, um die Sitzung zu speichern und so eine Sitzung aufzubauen Im PHP-Cluster kann auf diese Weise eine stabile Sitzung gewährleistet werden. Selbst wenn ein Knoten ausfällt, geht die Sitzung nicht verloren. Dies ist für strengere Anlässe, aber ein geringes Anforderungsvolumen geeignet. Allerdings ist seine Effizienz nicht sehr hoch und es eignet sich nicht für Anlässe, die eine hohe Effizienz erfordern.
Die beiden oben genannten Methoden haben nichts mit Nginx zu tun. Lassen Sie uns über die Verwendung von Nginx sprechen:
3) ip_hash
Die ip_hash-Technologie in nginx kann die Anfrage einer bestimmten IP an dasselbe Backend weiterleiten, sodass ein bestimmter Client und ein bestimmtes Backend unter dieser IP eine stabile Sitzung aufbauen können. ip_hash ist in der Konfiguration definiert:
Upstream-Backend {
Server 127.0.0.1:8001;
Server 127.0.0.1: 8002;
ip_hash;
}
ip_hash ist leicht zu verstehen, aber da es den IP-Faktor nur im Backend zuweisen kann, ist ip_hash defekt und kann in einigen Fällen nicht verwendet werden:
1/ Nginx ist kein Front-End-Server. ip_hash erfordert, dass nginx der Front-End-Server sein muss. Andernfalls kann nginx nicht die richtige IP erhalten und kann keinen Hash basierend auf der IP durchführen. Wenn beispielsweise Squid als Frontend verwendet wird, kann Nginx beim Abrufen der IP nur die Server-IP-Adresse von Squid abrufen. Es ist definitiv verwirrend, diese Adresse für die Verteilung zu verwenden.
2/ Das Backend von Nginx verfügt auch über andere Methoden zum Lastausgleich. Wenn das Nginx-Backend über eine andere Lastverteilung verfügt und die Anfragen auf andere Weise umgeleitet werden, dann wird eine Anfrage eines bestimmten Clients mit Sicherheit nicht auf demselben Sitzungsanwendungsserver liegen. Bei dieser Berechnung kann das Nginx-Backend nur direkt auf den Anwendungsserver verweisen oder einen Squid erstellen und dann auf den Anwendungsserver verweisen. Der beste Weg besteht darin, den Standort als Umleitung zu nutzen, einige Anfragen, die eine Sitzung erfordern, über ip_hash umzuleiten und für den Rest zu anderen Backends zu gehen.
4) upstream_hash
Um einige Probleme von ip_hash zu lösen, können Sie das Drittanbietermodul upstream_hash verwenden. Dieses Modul wird als url_hash verwendet In den meisten Fällen wird die Verwendung für die Sitzungsfreigabe jedoch nicht verhindert:
Wenn das Frontend Squid ist, wird die IP zum x_forwarded_for http_header hinzugefügt und zur Verwendung upstream_hash verwendet Dieser Header dient als Faktor zur Weiterleitung der Anfrage. Direkt an das angegebene Backend:
Siehe dieses Dokument:
http://www.oschina.net/ diskutiere/thread/622
Im Dokument wird $request_uri als Faktor verwendet, leicht geändert:
hash $http_x_forwarded_for;
Auf diese Weise wurde geändert, um den x_forwarded_for-Header als Faktor zu verwenden. In der neuen Version von nginx kann das Lesen von Cookie-Werten unterstützt werden, daher kann es auch geändert werden in:
hash $cookie_jsessionid;
Wenn die in PHP konfigurierte Sitzung kein Cookie ist, kann nginx das nginx-eigene Modul userid_module verwenden, um ein Cookie zu generieren. Bitte beachten Sie die englische Dokumentation des Userid-Moduls:
http://wiki.nginx.org/NginxHttpUserIdModule
Das Obige stellt verschiedene Methoden für den Nginx-Load-Balancer zur Verwaltung der Sitzungsfreigabe vor, einschließlich Aspekten des Inhalts. Ich hoffe, dass es für Freunde hilfreich ist, die an PHP-Tutorials interessiert sind.

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

So konfigurieren Sie einen Nginx -Domänennamen auf einem Cloud -Server: Erstellen Sie einen Datensatz, der auf die öffentliche IP -Adresse des Cloud -Servers zeigt. Fügen Sie virtuelle Hostblöcke in die NGINX -Konfigurationsdatei hinzu, wobei der Hörport, Domänenname und das Root -Verzeichnis der Website angegeben werden. Starten Sie Nginx neu, um die Änderungen anzuwenden. Greifen Sie auf die Konfiguration des Domänennamens zu. Weitere Hinweise: Installieren Sie das SSL -Zertifikat, um HTTPS zu aktivieren, sicherzustellen, dass die Firewall den Verkehr von Port 80 ermöglicht, und warten Sie, bis die DNS -Auflösung wirksam wird.

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.

Sie können den Namen des Docker -Containers abfragen, indem Sie den Schritten folgen: Alle Container auflisten (Docker PS). Filtern Sie die Containerliste (unter Verwendung des GREP -Befehls). Ruft den Containernamen ab (befindet sich in der Spalte "Namen").

Die Methoden, die die Nginx -Version abfragen können, sind: Verwenden Sie den Befehl nginx -v; Zeigen Sie die Versionsrichtlinie in der Datei nginx.conf an. Öffnen Sie die Nginx -Fehlerseite und sehen Sie sich den Seitentitel an.

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.

Das Starten eines Nginx-Servers erfordert unterschiedliche Schritte gemäß verschiedenen Betriebssystemen: Linux/UNIX-System: Installieren Sie das NGINX-Paket (z. B. mit APT-Get oder Yum). Verwenden Sie SystemCTL, um einen Nginx -Dienst zu starten (z. B. sudo systemctl start nginx). Windows -System: Laden Sie Windows -Binärdateien herunter und installieren Sie sie. Starten Sie Nginx mit der ausführbaren Datei nginx.exe (z. B. nginx.exe -c conf \ nginx.conf). Unabhängig davon, welches Betriebssystem Sie verwenden, können Sie auf die Server -IP zugreifen

Erstellen Sie einen Container in Docker: 1. Ziehen Sie das Bild: Docker Pull [Spiegelname] 2. Erstellen Sie einen Container: Docker Ausführen [Optionen] [Spiegelname] [Befehl] 3. Starten Sie den Container: Docker Start [Containername]

Startschritte des Docker -Containers: Ziehen Sie das Containerbild: Führen Sie "Docker Pull [Mirror Name]" aus. Erstellen eines Containers: Verwenden Sie "Docker erstellen [Optionen] [Spiegelname] [Befehle und Parameter]". Starten Sie den Container: Führen Sie "Docker Start [Container Name oder ID]" aus. Containerstatus überprüfen: Stellen Sie sicher, dass der Container mit "Docker PS" ausgeführt wird.
