Im Servercluster übernimmt Nginx die Rolle eines Proxyservers (d. h. Reverse-Proxy). Um übermäßigen Druck auf einen einzelnen Server zu vermeiden, leitet es Anfragen von Benutzern an verschiedene Server weiter. Mithilfe des Lastausgleichs wird ein Server aus der vom „Upstream“-Modul definierten Back-End-Serverliste ausgewählt, um Benutzeranfragen anzunehmen.
Mehrere gängige Methoden des Lastausgleichs
1. Abfrage (Standard)
Jede Anfrage Sie werden zugewiesen nacheinander in chronologischer Reihenfolge auf verschiedene Back-End-Server übertragen. Wenn der Back-End-Server ausfällt, kann er automatisch eliminiert werden.
1 2 3 4 |
|
2. Gewichtung
gibt die Abfragewahrscheinlichkeit an. Die Gewichtung ist proportional zum Zugriffsverhältnis und wird verwendet, wenn die Back-End-Serverleistung ungleichmäßig ist.
1 2 3 4 |
|
Je höher das Gewicht, desto größer die Zugriffswahrscheinlichkeit. Wie im obigen Beispiel liegen sie bei 30 % bzw. 70 %.
3. ip_hash
Ein Problem mit der oben genannten Methode besteht darin, dass sich der Benutzer im Lastausgleichssystem anmeldet, wenn er eine zweite Anfrage stellt, weil Wir sind ein Lastausgleichssystem. Jede Anfrage wird an einen bestimmten Server-Cluster umgeleitet. Wenn ein Benutzer, der sich an einem Server angemeldet hat, an einen anderen Server weitergeleitet wird, gehen seine Anmeldeinformationen verloren.
Wir können die ip_hash-Anweisung verwenden, um dieses Problem zu lösen. Wenn der Kunde einen bestimmten Server bereits besucht hat, wird die Anfrage beim erneuten Besuch automatisch über den Hash-Algorithmus an den Server weitergeleitet.
Jede Anfrage wird entsprechend dem Hash-Ergebnis der Zugriffs-IP zugewiesen, sodass jeder Besucher festen Zugriff auf einen Back-End-Server hat, der das Sitzungsproblem lösen kann.
1 2 3 4 5 |
|
4. Fair (Drittanbieter)
Anfragen werden entsprechend der Antwortzeit des Backend-Servers zugewiesen, und diejenigen mit kurzen Antwortzeiten werden zuerst zugewiesen.
1 2 3 4 5 |
|
5. url_hash (Dritter)
Anfragen entsprechend dem Hash-Ergebnis der aufgerufenen URL verteilen, sodass jede URL an denselben Back-End-Server weitergeleitet wird wenn der Back-End-Server zwischengespeichert ist.
1 2 3 4 5 6 |
|
Der Status jedes Geräts ist eingestellt auf:
1), down bedeutet, dass der Server vor dem einzelnen Gerät vorübergehend nicht an der Last teilnimmt
2) , Gewicht ist standardmäßig 1. Das Gewicht überschreitet. Je größer es ist, desto größer ist das Gewicht der Ladung.
3), max_fails: Die Anzahl der zulässigen Anforderungsfehler beträgt standardmäßig 1. Wenn die maximale Anzahl überschritten wird, wird der vom Modul „proxy_next_upstream“ definierte Fehler zurückgegeben
4), fail_timeout: Nach max_fails Fehler, die Zeit.
5), Backup: Wenn alle anderen Nicht-Backup-Maschinen ausgefallen oder ausgelastet sind, fordern Sie die Backup-Maschine an. Daher wird diese Maschine den geringsten Druck haben.
Konfigurationsbeispiel:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
|
Das obige ist der detaillierte Inhalt vonWas sind die Implementierungsmethoden für den Nginx-Lastausgleich?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!