Dieses Tutorial untersucht effiziente PHP -Techniken zum Umgang mit großen Dateien und konzentriert sich auf die Minimierung des Speicherverbrauchs. Wir werden mehrere Ansätze untersuchen und ihre Gedächtnisnutzung messen, um ihre Wirksamkeit zu demonstrieren. Der Schlüssel besteht darin, zu vermeiden, dass die gesamte Datei gleichzeitig in den Speicher geladen wird.
Schlüsselstrategien:
line-by-line-Lesung: Verwenden Sie fopen()
und fgets()
in einer Schleifenverarbeitungsdateienzeile für Zeile, wodurch der Speicherpfunddruck drastisch reduziert wird. Generatoren verbessern dies weiter, indem sie nacheinander Linien ergeben.
Stream -Rohrleitungen: Die Verwendung stream_copy_to_stream()
überträgt die Daten zwischen Streams (Dateien oder URLs) effizient, wobei die Speicherverwendung durch direkte Verarbeitung von Daten zwischen den Quellen minimiert wird. Dies ist besonders nützlich, wenn Sie die Daten selbst nicht manipulieren müssen.
Stream-Filter: Hebel-Stream-Filter für die Manipulation von Daten auf der Fliege wie Komprimierung (Zlib.Deflate) und Dekompression (Zlib.inflate). Dies optimiert die Speicherverwendung und -leistung.
benutzerdefinierte Stream-Kontexte: Verhalten des Feinsteuerstroms mit benutzerdefinierten Kontexten, die Kontrolle über Header, Methoden (wie Postanforderungen) und andere Parameter bieten.
benutzerdefinierte Protokolle und Filter (erweitert): Erstellen Sie für komplexe Szenarien benutzerdefinierte Protokolle und Filter, um die spezifischen Datenverarbeitungsanforderungen mit maximaler Speicher -Effizienz zu verarbeiten. Dies erfordert eine fortschrittlichere Programmierung, bietet jedoch ein erhebliches Potenzial für die Optimierung.
Speicherverbrauch messen:
Wir werden memory_get_peak_usage()
und eine Helferfunktion (formatBytes
) verwenden, um den Speicherverbrauch im gesamten Tutorial zu verfolgen. Dies ermöglicht einen direkten Vergleich verschiedener Methoden. Während die CPU -Verwendung auch ein Faktor ist, ist es weniger praktisch, direkt innerhalb von Php zu messen.
Szenario 1: Verarbeitungsdatenzeile nach Zeile
Wir werden demonstrieren, dass das Lesen einer großen Textdatei (Shakespeares vollständige Werke) das Lesen von Stücken basierend auf leeren Zeilen aufteilt. Der Vergleich zwischen einem naiven Ansatz und einem generatorbasierten Ansatz unterstreicht die erreichten Speichereinsparungen.
Szenario 2: Rohrdaten zwischen Dateien
Wir vergleichen die Speicherverwendung des direkten Kopierens einer Datei mit file_put_contents
und file_get_contents
mit der Streaming der Datei mit stream_copy_to_stream
. Letzteres reduziert den Speicherverbrauch erheblich. Wir werden auch Rohrleitungen aus einer Remote -URL (z. B. ein CDN -Bild) demonstrieren.
Szenario 3: Verwenden von Stream -Filtern
Dieser Abschnitt zeigt, wie eine Datei mit Stream-Filtern komprimiert und dekomprimiert wird und eine speichereffiziente Alternative zu herkömmlichen Komprimierungsmethoden anbietet.
Szenario 4: Anpassen von Streams und erweiterten Techniken
In diesem Abschnitt wird kurz das Konzept des Erstellens benutzerdefinierter Stream -Kontexte, Protokolle und Filter vorgestellt. Während die Implementierungsdetails über den Rahmen dieses Tutorials hinausgehen, wird das Potenzial für eine erweiterte Speicheroptimierung hervorgehoben.
Dieser strukturierte Ansatz bietet ein umfassendes Verständnis der effizienten großen Dateibearbeitung in PHP und befähigt Entwickler, die optimale Methode für ihre spezifischen Bedürfnisse zu wählen und die Leistung und Ressourceneffizienz ihrer Anwendungen erheblich zu verbessern. Denken Sie daran, Ihre Ergebnisse immer zu messen, um die Wirksamkeit Ihrer gewählten Strategie zu bestätigen.
Das obige ist der detaillierte Inhalt vonSo lesen Sie große Dateien mit PHP (ohne Ihren Server zu töten). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!