Speicherverlust bezieht sich auf das Phänomen, dass während der Ausführung des Programms Speicher beansprucht, aber nach Abschluss der Nutzung nicht rechtzeitig freigegeben wird. Bei normalen Programmen mit kurzer Laufzeit ist das Problem möglicherweise nicht so offensichtlich für Programme mit langer Laufzeit Dies ist bei Programmen wie Webservern, Hintergrundprozessen usw. offensichtlicher. Während das System läuft, nimmt der belegte Speicher weiter zu und kann aufgrund übermäßiger Speichernutzung abstürzen oder vom System abgebrochen werden ( OOM).
Speicherlecks in PHP
PHP ist eine Hochsprache. Es gibt kein Speicherkonzept auf Sprachebene. Daher ist es nicht erforderlich, Speicher aktiv zu beantragen oder freizugeben Auf der Ebene des PHP-Benutzercodes gibt es kein Konzept mehr für Speicherverluste.
Wenn Ihr PHP-Programm einen Speicherverlust aufweist oder große Variablen nicht rechtzeitig freigegeben werden, liegt ein Problem mit der Implementierung der Drittanbieter-Erweiterung selbst vor.
Hier ist eine kurze Einführung in das Funktionsprinzip des Nginx+php-fpm-Modus:
Der Nginx-Server verteilt n untergeordnete Prozesse (Worker) und der PHP-FPM-Manager verteilt n untergeordnete Prozesse.
Wenn eine Benutzeranfrage vorliegt, empfängt ein Nginx-Worker die Anfrage und wirft die Anfrage in den Socket.
Der inaktive Unterprozess von php-fpm lauscht auf Anfragen im Socket, empfängt und verarbeitet die Anfragen.
Ich möchte mich hier auf den dritten Schritt konzentrieren. Der dritte Schritt umfasst den Lebenszyklus des PHP-FPM-Prozesses. Der Lebenszyklus eines PHP-FPM ist ungefähr so: Modulinitialisierung (MINIT) -> Modulaktivierung (RINIT) -> Anforderungsverarbeitung -> Moduldeaktivierung (RSHUTDOWN)... Modulaktivierung (RINIT) -> Moduldeaktivierung (RSHUTDOWN) -> Im Lebenszyklus eines PHP-FPM-Prozesses gibt es mehrere Prozesse zur Modulaktivierung (RINIT) -> Anforderungsverarbeitung -> Moduldeaktivierung (RSHUTDOWN). Der allgemeine Prozess dieser „Anforderungsverarbeitung“ ist wie folgt: PHP liest die entsprechende PHP-Datei, führt eine lexikalische Analyse durch, generiert Opcode und die virtuelle Zend-Maschine führt den Opcode aus.
Das „memory_limit“ in der PHP-Konfigurationsdatei begrenzt eigentlich nur den Speicher für die „Anfrageverarbeitung“. Daher hat dieser Parameter nichts mit dem vom PHP-FPM-Prozess belegten Speicher zu tun.
Gibt es also eine Möglichkeit, dieses Problem zu verhindern?
In php-fpm.conf gibt es einen Parameter pm.max_requests, der PHP_FCGI_MAX_REQUESTS entspricht. Dieser Wert gibt an, wie viele Anfragen ein FPM-Prozess verarbeitet, bevor er automatisch beendet wird und ein neuer Prozess gestartet wird.
Speicherleck-Debugging und -Tools
Speicherleck-Programme sind normalerweise leicht zu finden, da sich die Symptome in einem kontinuierlichen Anstieg der Speichernutzung äußern. Nachdem wir festgestellt haben, dass der Speicher weiter wächst, müssen wir dies feststellen Was verursacht es? Wenn ein Speicherverlust auftritt, müssen Sie häufig einige Tools verwenden, um ihn aufzuspüren. Wir können zwei Tools verwenden: die in PHP integrierte Speicherleckerkennung und die Valgrind-Speicherleckanalyse.
Verwandte Empfehlungen:
Beispiele für den Umgang mit JavaScript-Speicherlecks teilen
PHP-Kernel-Bild von Speicherlecks und neuem Müll Sammelmechanismus Artikeleinführung
Was ist ein Speicherverlust, die Ursachen und Präventionsmethoden von Speicherverlusten
Das obige ist der detaillierte Inhalt vonDetaillierte Erklärung des PHP-Speicherlecks. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!