Heim > Backend-Entwicklung > PHP-Tutorial > Detaillierte Erklärung des PHP-Speicherlecks

Detaillierte Erklärung des PHP-Speicherlecks

小云云
Freigeben: 2023-03-21 21:58:01
Original
5313 Leute haben es durchsucht

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.

Speicherverlust durch PHP-FPM

Hier ist eine kurze Einführung in das Funktionsprinzip des Nginx+php-fpm-Modus:

  1. Der Nginx-Server verteilt n untergeordnete Prozesse (Worker) und der PHP-FPM-Manager verteilt n untergeordnete Prozesse.

  2. Wenn eine Benutzeranfrage vorliegt, empfängt ein Nginx-Worker die Anfrage und wirft die Anfrage in den Socket.

  3. 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!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage