Detaillierte Einführung in die Garbage Collection von NodeJS
Dieser Artikel bietet Ihnen eine detaillierte Einführung in die Garbage Collection von nodejs. Freunde in Not können darauf verweisen.
Der Garbage-Collection-Mechanismus von NodeJS wird automatisch von der v8-Engine verwaltet.
Speicherbeschränkung von NodeJS
In allgemeinen Back-End-Sprachen (PHP) gibt es keine Begrenzung der Speichernutzung, aber für NodeJS heißt es dass nur ein Teil des Systems genutzt werden kann – 1,4 G für 64-Bit-Systeme und 0,7 G für 32-Bit-Systeme. Wenn Sie zu diesem Zeitpunkt eine 3G-Datei für die Datenanalyse verarbeiten möchten, läuft der Prozessspeicher des Knotenjs immer noch über, selbst wenn der Systemspeicher 8 GB beträgt.
Das obige Problem wird hauptsächlich durch die Tatsache verursacht, dass NodeJS auf Version 8 basiert und NodeJS den Speicher über die eigene Methode von Version 8 verwaltet. Warum begrenzt Version 8 die Größe des Heap-Speichers? Es gibt zwei Gründe:
1. Oberflächlicher Grund: v8 ist für Browser konzipiert und es ist unwahrscheinlich, dass es zu großen Speicherszenarien kommt.
2. Tiefer Grund: Einschränkungen des v8-Garbage-Collection-Mechanismus. Am Beispiel von 1,5 GB Heap-Speicher benötigt Version 8 50 ms für eine kleine Garbage Collection und 1 s für eine nicht inkrementelle Garbage Collection. Die Garbage Collection führt dazu, dass der JS-Thread angehalten wird. Bei einem solchen Zeitaufwand sinken die Leistung und die Reaktionsfähigkeit der Anwendung.
Speicherlimit kann aktiviert werden:
--max-old-space-size (alte Generation)
--max-new-space-size (neue Generation)
v8-Heap Speichergröße = alte Generation + neue Generation
v8-Garbage-Collection-Mechanismus
v8-Garbage-Collection basiert hauptsächlich auf dem generationalen Garbage-Collection-Mechanismus. Die Speicherbereinigung erfolgt in verschiedenen Generationen entsprechend der Überlebenszeit des Objekts, und unterschiedliche Algorithmen werden für verschiedene Speichergenerationen ausgeführt.
Neue Generation ---> Objekte mit kurzer Überlebenszeit
Alte Generation ---> Objekte mit langer Überlebenszeit oder residentem Speicher
Wie oben erwähnt, ist die Größe des NodeJS-Heapspeichers die neue Speicherplatz der alten Generation plus Speicherplatz der alten Generation.
Algorithmus der neuen Generation
Die neue Generation verwendet hauptsächlich den Scavenge-Algorithmus für die Speicherbereinigung.
Dies ist eine Kopiermethode zur Implementierung der Garbage Collection. Der Heap-Speicher ist in zwei Bereiche unterteilt, und jeder Bereich wird als Semispace bezeichnet. Von diesen beiden Halbräumen ist nur einer in Gebrauch (aus dem Raum gerufen) und der andere ist frei (in den Raum gerufen). Wenn wir mit der Zuordnung beginnen, beginnen wir zunächst mit dem From-Bereich. Wenn die Speicherbereinigung beginnt, überprüfen wir auch die überlebenden Objekte, kopieren die überlebenden Objekte in den To-Bereich und den von den nicht überlebenden Objekten belegten Speicherplatz freigelassen werden. Nachdem der Kopiervorgang abgeschlossen ist, werden die Rollen des Von-Bereichs und des Bis-Bereichs vertauscht.
Wie Sie dem obigen Prozess entnehmen können, besteht der Nachteil von Scavenge darin, dass nur die Hälfte des Heap-Speichers verwendet wird, wodurch Zeit für die Platzbeschaffung verloren geht.
Die alte Generation übergibt die Mark-Sweep- und Mark-Comopact-Algorithmen.
Mark-Sweep-Markierungsentfernung ist in zwei Phasen unterteilt: Markieren und Löschen. Mark-Sweep durchläuft zunächst alle Objekte im Heap-Speicher in der Markierungsphase und markiert die verbleibenden Objekte. In der Löschphase werden nicht markierte Objekte gelöscht. Es ist ersichtlich, dass Scavenge nur lebende Objekte kopiert und Mark-Sweep nur tote Objekte bereinigt. Da die überlebenden Objekte der neuen Generation einen kleinen Teil und die toten Objekte der alten Generation einen kleinen Teil einnehmen, sind diese beiden Algorithmen aus diesem Grund effizient.
Mark-Compact-Markierungsorganisation, es wird ein Problem beim Mark-Sweep geben. Nach dem Recycling befindet sich der Speicher in einem diskontinuierlichen Zustand (Speicherfragmentierung). Die Speicherfragmentierung wirkt sich auf die nachfolgende Speicherzuweisung aus, da eine große Speicherzuweisung erforderlich ist, die Zuweisung jedoch nicht für alle Speicherfragmente abgeschlossen werden kann. Dadurch wird die Speicherbereinigung im Voraus ausgelöst, und diese Wiederverwertung ist unnötig. Mark-Compact wurde auf der Grundlage von Mark-Sweep entwickelt. Der Hauptunterschied besteht darin, dass nach der Markierung des Objekts alle verbleibenden Objekte während des Sortiervorgangs an ein Ende verschoben und direkt nach Abschluss der Bewegung gelöscht werden.
Zusammenfassung: Bei normaler Nutzung ist das Speicherlimit von v8 immer noch ausreichend, aber die Garbage Collection und der einzelne Thread von nodejs beeinträchtigen weiterhin die Leistung. Wenn Sie eine hohe Leistung wünschen, müssen Sie die Speicherbereinigung so klein wie möglich halten. In der tatsächlichen Entwicklung müssen Objekte der alten Generation verwendet werden, z. B. bei der Implementierung einer Webdienstsitzung (Sitzung), die im Allgemeinen im Speicher (Array) gespeichert wird. Wenn die Zugriffsmenge groß ist, führt dies zu einem starken Anstieg der alten Generierungsobjekte, die zu einem Überlauf führen können. Wenn wir große Speicherdaten verarbeiten müssen, z. B. das Lesen einer 3G-Datei, verwenden wir die Pipe () -Methode des lesbaren Streams, damit dieser nicht von den Speicherbeschränkungen der Version 8 betroffen ist und die Robustheit des NodeJS-Programms verbessert wird.
Das obige ist der detaillierte Inhalt vonDetaillierte Einführung in die Garbage Collection von NodeJS. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Dieser Artikel vermittelt Ihnen ein detailliertes Verständnis des Speichers und Garbage Collectors (GC) der NodeJS V8-Engine. Ich hoffe, er wird Ihnen hilfreich sein!

Der nicht blockierende und ereignisgesteuerte Knotendienst hat den Vorteil eines geringen Speicherverbrauchs und eignet sich sehr gut für die Verarbeitung massiver Netzwerkanforderungen. Unter der Voraussetzung massiver Anfragen müssen Probleme im Zusammenhang mit der „Speicherkontrolle“ berücksichtigt werden. 1. Der Garbage-Collection-Mechanismus und die Speicherbeschränkungen von V8 Js wird von der Garbage-Collection-Maschine gesteuert

Die Auswahl eines Docker-Images für Node mag trivial erscheinen, aber die Größe und potenziellen Schwachstellen des Images können erhebliche Auswirkungen auf Ihren CI/CD-Prozess und Ihre Sicherheit haben. Wie wählen wir also das beste Node.js-Docker-Image aus?

Das Dateimodul ist eine Kapselung der zugrunde liegenden Dateioperationen, wie z. B. Lesen/Schreiben/Öffnen/Schließen/Löschen von Dateien, Hinzufügen usw. Das größte Merkmal des Dateimoduls besteht darin, dass alle Methoden zwei Versionen von **synchronem** und **bereitstellen. asynchron**, mit Methoden mit dem Suffix sync sind alle Synchronisationsmethoden, und diejenigen ohne sind alle heterogene Methoden.

Node 19 wurde offiziell veröffentlicht. Dieser Artikel wird Ihnen eine detaillierte Erklärung der 6 Hauptfunktionen von Node.js 19 geben. Ich hoffe, er wird Ihnen hilfreich sein!

Wie führt Node.js GC (Garbage Collection) durch? Der folgende Artikel führt Sie durch.

Die Ereignisschleife ist ein grundlegender Bestandteil von Node.js und ermöglicht die asynchrone Programmierung, indem sie sicherstellt, dass der Hauptthread nicht blockiert wird. Das Verständnis der Ereignisschleife ist für die Erstellung effizienter Anwendungen von entscheidender Bedeutung. Der folgende Artikel wird Ihnen ein detailliertes Verständnis der Ereignisschleife in Node vermitteln. Ich hoffe, er wird Ihnen hilfreich sein!

Der Grund, warum der Knoten den Befehl npm nicht verwenden kann, liegt darin, dass die Umgebungsvariablen nicht richtig konfiguriert sind. Die Lösung ist: 1. Öffnen Sie „Systemeigenschaften“ 2. Suchen Sie nach „Umgebungsvariablen“ -> „Systemvariablen“ und bearbeiten Sie dann die Umgebung Variablen; 3. Suchen Sie den Speicherort des NodeJS-Ordners. 4. Klicken Sie auf „OK“.
