Sites, die Apache als HTTP-Server verwenden, werden zwangsläufig auf dieses Problem stoßen: Apache hat eine sehr geringe Auslastung, aber der Zugriff auf den Webserver ist sehr langsam. Nachdem die Ursache des Skriptprogramms ausgeschlossen wurde, handelt es sich im Wesentlichen um ein Problem mit den Apache-Einstellungen.
Der folgende Inhalt kann zur Lösung dieses Problems beitragen.
1. Zuerst müssen Sie die von Apache verwendeten MPM (Multi-Processing Modules) verstehen
MPM ist der Kern von Apache. Seine Aufgabe besteht darin, Netzwerkverbindungen zu verwalten und Anfragen zu planen.
MPM in Apache2.0 ist in drei Typen unterteilt (Perfork, Worker, Event). Perfork ist von Apache 1.3 geerbt und verwendet die Prozessverwaltungsmethode, sodass eine zuverlässigere Leistung und bessere Kompatibilität gewährleistet werden können. Worker ist eine neu hinzugefügte Methode in Apache 2.0, die die Thread-Steuerungsmethode verwendet, wodurch Systemaufwand gespart und mehr verarbeitet werden kann Daten als Perfork, aber gleichzeitig ist die Kompatibilität nicht sehr gut, und viele alte Programme können unter dem Worker-Event noch nicht verwendet werden, da es jeder Aufgabe unterschiedliche Prozesse zuweist zu diesem Zeitpunkt.
Sie können den Befehl httpd -l verwenden, um herauszufinden, welches MPM derzeit von Apache verwendet wird
In diesem Artikel wird nur die Perfork-Methode behandelt
2. Verstehen Sie, wie Perfork funktioniert
Überprüfen Sie die Konfigurationsdatei httpd.conf von Apache2.0 und Sie können den Perfork-Konfigurationsabschnitt sehen, der ungefähr wie folgt lautet:
ServerLimit 256
StartServer 5
MinSpareServers 10
MaxSpareServers 15
MaxClients 256
MaxRequestsPerChild 4000
Wenn Apache gestartet wird, erstellt Apache automatisch StartServers-Prozesse und versucht sein Bestes, um die Anzahl der inaktiven Prozesse zwischen MinSpareServers und MaxSpareServers beizubehalten.
Wenn die inaktiven Prozesse kleiner sind als MinSpareServers, erstellt Apache neue Prozesse mit einer Rate von etwa 1 pro Sekunde.
Wenn die inaktiven Prozesse kleiner als MaxSpareServers sind, löscht Apache überschüssige inaktive Prozesse und gibt Serverressourcen frei.
Die maximale Anzahl von Prozessen wird von MaxClients gesteuert. In Apache1.3 kann das Maximum nur auf 256 festgelegt werden. In Apache2.0 können Sie jedoch die Grenze von 256 überschreiten, indem Sie das ServerLimit-Element zu Beginn der Konfiguration hinzufügen. In diesem Fall ist MaxClients ≤ ServerLimit ≤ 20000
MaxRequestsPerChild wird verwendet, um zu steuern, wie viele Anforderungen jeder Prozess nach der Verarbeitung automatisch zerstört. Dieser Parameter kann auf 0 gesetzt werden, um eine unbegrenzte Anzahl anzuzeigen (dh der Prozess wird nicht zerstört).
3. Perfork optimieren
Erstens reicht für eine Website mit relativ hoher Auslastung das Prozesslimit von 256 nicht aus. Wenn der Server das Limit von 256 erreicht hat, muss der nächste Zugriff in die Warteschlange gestellt werden. Aus diesem Grund ist die Auslastung einiger Server nicht ausreichend nicht hoch, aber einer der Gründe, warum der Zugriff so langsam ist. Daher sollten Sie zunächst die Anzahl der Prozesse auf dem Server verstehen, wenn dieser ausgelastet ist.
Mit dem Befehl ps -ef|grep httpd|wc -l können Sie die Anzahl der Apache-Prozesse im aktuellen System ermitteln und den Zweck der sanften Erweiterung des Servers durch Festlegen von ServerLimit und MaxClients erreichen.
Dann kommt es in Spitzenverkehrszeiten oft vor, dass es plötzlich viele gleichzeitige Verbindungen gibt und dann plötzlich viel weniger Besuche. Wenn Apache nicht genügend Vorbereitungsprozesse vorbereitet, kann der Zugriff nur darauf warten, dass Apache einen neuen Prozess pro Sekunde hinzufügt, und dann die redundanten Prozesse löschen. Dann kann Apache nur mit dem Erstellen und Zerstören von Prozessen beschäftigt sein, was den Zugriff erheblich einschränkt. Geschwindigkeit. Sie können StartServers, MinSpareServers und MaxSpareServers entsprechend erhöhen, sodass Apache nicht mit nutzloser Arbeit beschäftigt sein muss.
Schließlich wird dringend empfohlen, MaxRequestsPerChild nicht auf 0, sondern auf einen Wert ungleich 0 zu setzen. Dies kann den Apache-Prozess vor Speicherverlusten schützen, da Sie nicht wissen, wann die unter Apache ausgeführte Anwendung einen Fehler verursacht und Speicher verursacht Lecks.
Nach der Einrichtung sieht es so aus:
ServerLimit 1000
StartServer 30
MinSpareServers 30
MaxSpareServers 45
MaxClients 1000
MaxRequestsPerChild 4000
Detaillierte Schritte http://www.liaoxiansheng.cn/?p=496