Heim Web-Frontend js-Tutorial Eine detaillierte Einführung in das Multiprozessmodul Cluster in Node.js und dessen Verwendung

Eine detaillierte Einführung in das Multiprozessmodul Cluster in Node.js und dessen Verwendung

May 27, 2017 am 10:44 AM

Wie wir alle wissen, ist Node.js Single-Threaded und ein einzelner Node.js-Prozess kann mehrere Kerne nicht vollständig nutzen. Ab v0.6.0 hat Node.js ein Cluster-Modul hinzugefügt, das die vollständige Nutzung von Multi-Core-Maschinen bei der Entwicklung von Webdiensten mit Node.js erleichtert. Dieser Artikel führt Sie hauptsächlich in die relevanten Informationen zum Multiprozessmodul Cluster in Node.js ein. Freunde, die sie benötigen, können sich auf

Vorwort

beziehen

Wir alle wissen, dass das größte Merkmal von NodeJS der nicht blockierende Einzelprozessbetrieb ist und asynchron ereignisgesteuert ist. Diese Funktionen von Nodejs können einige Probleme sehr gut lösen. Bei der Serverentwicklung ist beispielsweise die gleichzeitige Anforderungsverarbeitung ein großes Problem, und das Blockieren von Funktionen führt zu Ressourcenverschwendung und Zeitverzögerung. Durch die Ereignisregistrierung und asynchrone Funktionen können Entwickler die Ressourcennutzung verbessern und die Leistung verbessern. Da Node.js den Single-Process- und Single-Thread-Modus verwendet, wie kann Nodejs, das über eine hervorragende Single-Core-Leistung verfügt, in der heutigen Umgebung, in der Multi-Core-Hardware beliebt ist, die Vorteile von Multi-Core-CPUs nutzen? Gründer Ryan Dahl empfiehlt, mehrere Nodejs-Prozesse auszuführen und einen Kommunikationsmechanismus zur Koordinierung von Aufgaben zu verwenden. Derzeit wurden viele Node.js-Multiprozess-Unterstützungsmodule von Drittanbietern veröffentlicht, und die NodeJS-Versionen 0.6.x und höher bieten ein Clustermodul, das die Erstellung einer Gruppe von Prozessen ermöglicht, die „den gleichen Socket teilen“, um die Last zu teilen Druck. .

Dieser Artikel basiert auf dem Cluster-Modul und beschreibt die Node.js-Programmierung unter einer Multi-Core-CPU.

Einführung in das Clustermodul

Das von nodejs bereitgestellte Clustermodul befindet sich derzeit im experimentellen Stadium. Wir können es im offiziellen Dokument von v0 sehen .10.7 Die Release-Informationen zum Modul lauten wie folgt:


Stability: 1 - Experimental
Nach dem Login kopieren

Bezüglich der Funktion dieses Moduls beschreibt das Quelldokument Folgendes: „Eine einzelne Instanz von Node läuft in.“ Um die Vorteile von Multi-Core-Systemen nutzen zu können, möchte der Benutzer manchmal einen Cluster von Node-Prozessen starten, um die Last zu bewältigen Um die Ressourcen von Multi-Core-Systemen zu nutzen, müssen Benutzer einen Cluster von Knotenprozessen ausführen, um die Last zu teilen.

Einführung in die Clusternutzung

Veröffentlichen Sie zunächst einen Beispielanwendungscode dieses Moduls und führen Sie dann eine detaillierte Analyse durch. Der Code ist wie folgt folgt:


var cluster = require('cluster');
var http = require('http');
var numCPUs = require('os').cpus().length;

if (cluster.isMaster) {
 require('os').cpus().forEach(function(){
 cluster.fork();
 });
 cluster.on('exit', function(worker, code, signal) {
 console.log('worker ' + worker.process.pid + ' died');
 });
 cluster.on('listening', function(worker, address) { 
 console.log("A worker with #"+worker.id+" is now connected to " +
  address.address +
 ":" + address.port); 
 }); 
} else {
 http.createServer(function(req, res) {
 res.writeHead(200);
 res.end("hello world\n");
 console.log('Worker #' + cluster.worker.id + ' make a response');
 }).listen(8000);
}
Nach dem Login kopieren

Dieser Code ist sehr einfach. Der Hauptthread ist die aktuell ausgeführte js-Datei. Der Hauptthread erstellt untergeordnete Prozesse basierend auf der Anzahl Ihrer Kerne lokales System. Alle Prozesse teilen sich einen Überwachungsport 8000. Wenn eine Anfrage initiiert wird, weist der Hauptthread die Anfrage zufällig einem untergeordneten Prozess zu. console.log('Worker #' + cluster.worker.id + ' make a response');Dieser Code kann ausdrucken, welcher Prozess die Anfrage bearbeitet.

Problemanalyse

Wir haben bereits erwähnt, dass das System beim Initiieren einer Anfrage entscheidet, an welchen Prozess die Anfrage zur Bearbeitung übergeben wird. Diese Art des Lastausgleichs, der vollständig vom System abhängt, weist einen wichtigen Fehler auf: Unter Windows, Linux und Solaris bleibt das System leer, solange die Annahmewarteschlange eines bestimmten Unterprozesses leer ist (normalerweise der zuletzt erstellte Unterprozess). Verwenden Sie mehrere Verbindungen, die demselben Unterprozess zugewiesen sind. Dies führt zu einer extrem ungleichmäßigen Belastung zwischen den Prozessen. Insbesondere bei Verwendung langer Verbindungen ist die Anzahl der pro Zeiteinheit neu kommenden Verbindungen nicht hoch und die Annahmewarteschlange des untergeordneten Prozesses ist häufig leer, was dazu führt, dass Verbindungen kontinuierlich demselben Prozess zugewiesen werden. Daher hängt diese Art des Lastausgleichs vollständig von der Leerlaufzeit der Annahmewarteschlange ab. Der Lastausgleich kann nur erreicht werden, wenn kurze Verbindungen verwendet werden und die Parallelität sehr hoch ist Das System wird instabil.

Zusammenfassung

Das obige ist der detaillierte Inhalt vonEine detaillierte Einführung in das Multiprozessmodul Cluster in Node.js und dessen Verwendung. 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ßer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

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)

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

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!

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

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?

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

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!

See all articles