Wie Nginx Sitzungen teilt
Wenn Nginx einen Lastausgleich durchführt und die URL derselben IP den Server anfordert, leitet der Lastausgleich die Anfrage basierend auf der Gewichtung jedes Servers und anderen Einstellungen an verschiedene Server weiter Bei Statusanfragen handelt es sich um ein großes Problem. Die Sitzung kann nicht geteilt werden.
Die Sitzung existiert in Die Datenbank MySQL
Die Sitzung wird in der Datenbank gespeichert, in der die Sitzungstabelle und andere Datentabellen zusammen gespeichert werden. Wenn sich der Benutzer dann anmeldet und Vorgänge ausführt, muss er oder sie zur Datenbank gehen Um den Status der Sitzung zu überprüfen, erhöht sich zweifellos der Druck auf die MySQL-Datenbank. Wenn die Datenbank ebenfalls geclustert ist, muss jeder Knoten des Datenbankclusters die Sitzungstabelle und die Daten der Sitzungstabelle speichern In jedem Clusterknoten muss eine konsistente Echtzeitsynchronisierung erfolgen.
Erklärung: Die Sitzung wird in der Datenbank gespeichert, was die E/A der Datenbank erhöht und den Druck und die Belastung der Datenbank erhöht Dies beeinträchtigt die Lese- und Schreibleistung der Datenbank und ist nicht förderlich für die Echtzeitsynchronisation der Sitzung
Sitzung wird im Cache-Memcache oder Redis gespeichert
Memcache kann verteilt werden, und die Speichermethode ist in der PHP-Konfigurationsdatei auf Memcache eingestellt, sodass PHP es selbst erstellt. Ein Sitzungscluster speichert Sitzungsdaten im Memcache.
Erklärung: Diese Art der Sitzungssynchronisierung erhöht die Belastung der Datenbank nicht und die Sicherheit wird im Vergleich zur Verwendung von Cookies zum Speichern von Sitzungen erheblich verbessert. Allerdings unterteilt Memcache den Speicher in Speicherblöcke mit unterschiedlichen Spezifikationen, und jeder Block hat seine eigene Größe. Diese Methode bestimmt auch, dass Memcache den Speicher nicht vollständig nutzen kann und zu einer Speicherfragmentierung führt .
ip_hash-Technologie
kann in nginx konfiguriert werden, wenn ein Client unter einer bestimmten IP einen angegebenen (festen) anfordert, da ein Hash-Wert basierend auf der IP-Adresse berechnet wird Bestimmen Sie anhand des Hash-Werts, welcher Server zugewiesen ist, sodass jede IP-Anfrage dem angegebenen Server zugewiesen wird, sodass die Integrität des Status der Statusanforderung gewährleistet werden kann und kein Statusverlust auftritt ist nginx Konfiguration, Sie können sich auf Folgendes beziehen:
upstream nginx.example.com { server 192.168.1.2:80; server 192.168.1.3:80; ip_hash; } server { listen 80; location / { proxy_pass http://nginx.example.com; } }
Hinweis: ip_hash Diese Lösung kann zwar die Integrität von Anfragen mit Status sicherstellen, weist jedoch einen großen Fehler auf, nämlich die ip_hash-Lösung muss sicherstellen, dass Nginx der Front-End-Server ist (der eine echte IP akzeptiert). Wenn Nginx nicht der Front-End-Server ist und Middleware (Zwischenserver oder ähnliches) vorhanden ist, ist die von Nginx erhaltene IP-Adresse nicht die echte IP-Adresse. dann wird dieser ip_hash sein Es macht keinen Sinn
Weitere technische Artikel zu Nginx finden Sie in der Spalte Nginx-Tutorial, um mehr zu erfahren!
Das obige ist der detaillierte Inhalt vonWie Nginx Sitzungen teilt. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

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

Um dem Tomcat-Server den Zugriff auf das externe Netzwerk zu ermöglichen, müssen Sie Folgendes tun: Ändern Sie die Tomcat-Konfigurationsdatei, um externe Verbindungen zuzulassen. Fügen Sie eine Firewallregel hinzu, um den Zugriff auf den Tomcat-Server-Port zu ermöglichen. Erstellen Sie einen DNS-Eintrag, der den Domänennamen auf die öffentliche IP des Tomcat-Servers verweist. Optional: Verwenden Sie einen Reverse-Proxy, um Sicherheit und Leistung zu verbessern. Optional: Richten Sie HTTPS für mehr Sicherheit ein.

Die Start- und Stoppbefehle von Nginx lauten nginx bzw. nginx -s quit. Der Startbefehl startet den Server direkt, während der Stoppbefehl den Server ordnungsgemäß herunterfährt, sodass alle aktuellen Anforderungen verarbeitet werden können. Weitere verfügbare Stoppsignale sind Stopp und Nachladen.

Schritte zum lokalen Ausführen von ThinkPHP Framework: Laden Sie ThinkPHP Framework herunter und entpacken Sie es in ein lokales Verzeichnis. Erstellen Sie einen virtuellen Host (optional), der auf das ThinkPHP-Stammverzeichnis verweist. Konfigurieren Sie Datenbankverbindungsparameter. Starten Sie den Webserver. Initialisieren Sie die ThinkPHP-Anwendung. Greifen Sie auf die URL der ThinkPHP-Anwendung zu und führen Sie sie aus.

Um den Fehler „Willkommen bei Nginx!“ zu beheben, müssen Sie die Konfiguration des virtuellen Hosts überprüfen, den virtuellen Host aktivieren, Nginx neu laden. Wenn die Konfigurationsdatei des virtuellen Hosts nicht gefunden werden kann, erstellen Sie eine Standardseite und laden Sie Nginx neu. Anschließend wird die Fehlermeldung angezeigt verschwindet und die Website wird normal angezeigt.

Serverbereitstellungsschritte für ein Node.js-Projekt: Bereiten Sie die Bereitstellungsumgebung vor: Erhalten Sie Serverzugriff, installieren Sie Node.js, richten Sie ein Git-Repository ein. Erstellen Sie die Anwendung: Verwenden Sie npm run build, um bereitstellbaren Code und Abhängigkeiten zu generieren. Code auf den Server hochladen: über Git oder File Transfer Protocol. Abhängigkeiten installieren: Stellen Sie eine SSH-Verbindung zum Server her und installieren Sie Anwendungsabhängigkeiten mit npm install. Starten Sie die Anwendung: Verwenden Sie einen Befehl wie node index.js, um die Anwendung zu starten, oder verwenden Sie einen Prozessmanager wie pm2. Konfigurieren Sie einen Reverse-Proxy (optional): Verwenden Sie einen Reverse-Proxy wie Nginx oder Apache, um den Datenverkehr an Ihre Anwendung weiterzuleiten

Um sich für phpMyAdmin zu registrieren, müssen Sie zunächst einen MySQL-Benutzer erstellen und ihm Berechtigungen erteilen, dann phpMyAdmin herunterladen, installieren und konfigurieren und sich schließlich bei phpMyAdmin anmelden, um die Datenbank zu verwalten.

Nginx erscheint beim Zugriff auf die Website. Die Gründe können sein: Serverwartung, ausgelasteter Server, Browser-Cache, DNS-Probleme, Firewall-Blockierung, Website-Fehlkonfiguration, Netzwerkverbindungsprobleme oder die Website ist ausgefallen. Probieren Sie die folgenden Lösungen aus: Warten Sie, bis die Wartungsarbeiten beendet sind, besuchen Sie die Website außerhalb der Hauptverkehrszeiten, leeren Sie Ihren Browser-Cache, leeren Sie Ihren DNS-Cache, deaktivieren Sie Firewall- oder Antivirensoftware, wenden Sie sich an den Site-Administrator, überprüfen Sie Ihre Netzwerkverbindung oder verwenden Sie eine Suchmaschine oder Webarchiv, um eine weitere Kopie der Website zu finden. Wenn das Problem weiterhin besteht, wenden Sie sich bitte an den Site-Administrator.

In der Docker-Umgebung gibt es fünf Methoden für die Containerkommunikation: freigegebenes Netzwerk, Docker Compose, Netzwerk-Proxy, freigegebenes Volume und Nachrichtenwarteschlange. Wählen Sie abhängig von Ihren Isolations- und Sicherheitsanforderungen die am besten geeignete Kommunikationsmethode, z. B. die Nutzung von Docker Compose zur Vereinfachung von Verbindungen oder die Verwendung eines Netzwerk-Proxys zur Erhöhung der Isolation.
