Heim Web-Frontend js-Tutorial Detaillierte Einführung in die Garbage Collection von NodeJS

Detaillierte Einführung in die Garbage Collection von NodeJS

Oct 25, 2018 pm 04:08 PM
node.js

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!

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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Detaillierte grafische Erläuterung des Speichers und des GC der Node V8-Engine Detaillierte grafische Erläuterung des Speichers und des GC der Node V8-Engine Mar 29, 2023 pm 06:02 PM

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!

Ein Artikel über Speichersteuerung in Node Ein Artikel über Speichersteuerung in Node Apr 26, 2023 pm 05:37 PM

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

Lassen Sie uns darüber sprechen, wie Sie das beste Node.js-Docker-Image auswählen. Lassen Sie uns darüber sprechen, wie Sie das beste Node.js-Docker-Image auswählen. Dec 13, 2022 pm 08:00 PM

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?

Lassen Sie uns ausführlich über das File-Modul in Node sprechen Lassen Sie uns ausführlich über das File-Modul in Node sprechen Apr 24, 2023 pm 05:49 PM

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.js 19 ist offiziell veröffentlicht, lassen Sie uns über seine 6 Hauptfunktionen sprechen! Node.js 19 ist offiziell veröffentlicht, lassen Sie uns über seine 6 Hauptfunktionen sprechen! Nov 16, 2022 pm 08:34 PM

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!

Lassen Sie uns über den GC-Mechanismus (Garbage Collection) in Node.js sprechen Lassen Sie uns über den GC-Mechanismus (Garbage Collection) in Node.js sprechen Nov 29, 2022 pm 08:44 PM

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

Lassen Sie uns über die Ereignisschleife in Node sprechen Lassen Sie uns über die Ereignisschleife in Node sprechen Apr 11, 2023 pm 07:08 PM

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!

Was soll ich tun, wenn der Knoten den Befehl npm nicht verwenden kann? Was soll ich tun, wenn der Knoten den Befehl npm nicht verwenden kann? Feb 08, 2023 am 10:09 AM

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“.

See all articles