PHP verfügt über einen sehr einfachen Garbage Collector, der tatsächlich Objekte sammelt, die sich nicht mehr im Speicherbereich befinden. Die interne Funktionsweise der Garbage Collection besteht darin, einen Referenzzähler zu verwenden. Wenn der Zähler also 0 erreicht (was bedeutet, dass kein Verweis auf das Objekt verfügbar ist), wird das Objekt durch Garbage Collection gesammelt und aus dem Speicher entfernt.
Jede Computersprache verfügt über einen eigenen automatischen Garbage-Collection-Mechanismus, sodass sich Programmierer nicht zu viele Gedanken über die Programmspeicherzuweisung machen müssen. Bei der objektorientierten Programmierung (OOP) ist PHP jedoch keine Ausnahme. Einige Objekte müssen im Zerstörungsstil angezeigt werden.
1. PHP Garbage Collector (GC)
Wenn in PHP keine Variable auf dieses Objekt zeigt, wird das Objekt zu Müll. PHP zerstört es im Speicher. Dies ist der GC-Müllentsorgungsmechanismus von PHP, um einen Speicherüberlauf zu verhindern.
Wenn ein PHP-Thread endet, wird der gesamte aktuell belegte Speicherplatz zerstört und alle Objekte im aktuellen Programm werden gleichzeitig zerstört. Der GC-Prozess beginnt im Allgemeinen mit jeder SESSION. Der Zweck von gc besteht darin, die Sitzungsdateien nach ihrem Ablauf automatisch zu zerstören und zu löschen.
2 wird ausgeführt, wenn das Müllobjekt recycelt wird.
unset zerstört die Variable, die auf das Objekt zeigt, nicht das Objekt.
3. Sitzung und GC
Aufgrund des Arbeitsmechanismus von PHP gibt es keinen Daemon-Thread, um die Sitzungsinformationen regelmäßig zu scannen und festzustellen, ob sie ungültig sind , PHP Ob ein GC aktiviert werden soll, wird anhand der Werte der globalen Variablen session.gc_probability und session.gc_divisor bestimmt. Standardmäßig bedeutet session.gc_probability=1, session.gc_divisor =100, dass eine Wahrscheinlichkeit von 1 % besteht Starten des GC (das heißt, nur ein GC unter 100 Anfragen wird mit einer der 100 Anfragen gestartet).
Die Aufgabe von GC besteht darin, alle Sitzungsinformationen zu scannen und die letzte Änderungszeit davon zu subtrahieren Die Sitzung wird ab dem aktuellen Zeitpunkt abgerufen und gleichzeitig mit dem Parameter session.gc_maxlifetime verglichen. Wenn die Überlebenszeit gc_maxlifetime (Standard 24 Minuten) überschreitet, wird die Sitzung gelöscht.
Wenn Ihr Webserver jedoch über mehrere Sites verfügt, kann GC bei der Verarbeitung von Sitzungen an mehreren Sites zu unerwarteten Ergebnissen führen. Der Grund dafür ist: Wenn GC funktioniert, unterscheidet es nicht zwischen Sitzungen verschiedener Sites Wie kann man es zu diesem Zeitpunkt lösen?
1. Ändern Sie session.save_path oder verwenden Sie session_save_path(), um die Sitzung jeder Site in einem dedizierten Verzeichnis zu speichern.
2. Geben Sie die Startrate von GC an verbessert, und die Leistung des Systems wird entsprechend reduziert, was nicht zu empfehlen ist.
3. Bestimmen Sie die Überlebenszeit der aktuellen Sitzung im Code und löschen Sie sie mit session_destroy(). Bitte geben Sie die Quelle zum Nachdrucken an: Einführung in den Garbage-Collection-Mechanismus des PHP-Referenzzählers