Inhaltsverzeichnis
Prozess
Der Unterschied zwischen Prozess und Thread
“]Ist es wirklich Single-Threaded?
Interprozesskommunikation kommt nicht nur in Node, sondern auch in anderen Sprachen vor. Natürlich ist dies auch eine Frage, die im Vorstellungsgespräch unbedingt gestellt werden muss. Viele Inhalte können ausführlich besprochen werden!
Heim Web-Frontend js-Tutorial Ist Node.js wirklich Single-Threaded? Wie kommuniziert man zwischen Prozessen?

Ist Node.js wirklich Single-Threaded? Wie kommuniziert man zwischen Prozessen?

Aug 02, 2021 pm 06:44 PM
node.js einzelner Thread

Dieser Artikel führt Sie in Prozesse und Threads ein, bringt Ihnen das Verständnis der Threads in Node.js näher, zeigt Ihnen, ob der Knoten wirklich Single-Threaded ist, die Child_Process- und Cluster-Module und erläutert kurz die Kommunikation zwischen Multi-Threads .

Ist Node.js wirklich Single-Threaded? Wie kommuniziert man zwischen Prozessen?

Prozess

Im Betriebssystem ist die Erklärung des Prozesses: Ein Prozess ist ein dynamischer Ausführungsprozess eines Programms mit bestimmten unabhängigen Funktionen auf einem Datensatz. Es ist das Betriebssystem, das Ressourcen zuweist und plant . Eine unabhängige Einheit, die der Träger ist, auf dem die Anwendung ausgeführt wird.

  • ist ein laufender Prozess einer Anwendung (dynamisches Konzept)

  • ist die Grundeinheit für die Systemzuweisung und -planung von Ressourcen (ein Prozess besteht im Allgemeinen aus drei Teilen: Programm, Datenerfassung und Prozesssteuerungsblock)

  • Jeder Prozess verfügt über eine eigene unabhängige Raumadresse und einen eigenen Datenstapel (Daten werden nicht zwischen Prozessen geteilt und können über andere Methoden kommuniziert werden: Prozesse haben im Allgemeinen fünf Zustände: Anfangszustand, Ausführungszustand, Wartezustand, Bereitschaftszustand usw.). Beendigungszustand

Thread

Ein Thread ist ein einzelner sequenzieller Steuerungsprozess bei der Programmausführung. Er ist die kleinste Einheit des Programmausführungsflusses und die Grundeinheit der Prozessorplanung und -verteilung.

  • Die kleinste Einheit der Aufgabenplanung und -ausführung

  • Eine einzelne Ausführungsroute von Code in einem Prozess

Der Unterschied zwischen Prozess und Thread

Thread ist die kleinste Einheit der Programmausführung und des Prozesses ist die kleinste vom Betriebssystem zugewiesene Ressourceneinheit. Ein Einheitsprozess besteht aus einem oder mehreren Threads. Threads sind verschiedene Ausführungsrouten von Code in einem Prozess. Prozesse sind voneinander unabhängig, aber der Speicherplatz des Programms wird von Threads gemeinsam genutzt im selben Prozess. Der Thread-Kontextwechsel ist schneller als der Prozesskontextwechsel. Der Prozess im Knoten ist ein Single-Thread-Prozess, dh ein Prozess öffnet nur einen Thread-Knoten. [Empfohlenes Lernen: „

nodejs-Tutorial

“]Ist es wirklich Single-Threaded?

Knoten ist Single-Threaded, aber die darunter liegende Schicht ist Multithreaded. In der Ereignisschleife entnimmt die libuv-Bibliothek Aufgaben aus der Ereigniswarteschlange und weist sie verschiedenen Threads zur Verarbeitung zu. Jetzt sind die Hardwarebedingungen nicht mehr so ​​rückständig wie zuvor. Wenn nur ein einzelner Thread für den Betrieb verwendet wird, werden Ressourcen verschwendet. Um eine Multiprozessverarbeitung zu erreichen und die Vorteile von Multi-Core-CPUs voll auszuschöpfen, stellt Node daher das Modul child_process und das Clustermodul bereit.

child_process-Modul wird zum Starten mehrerer untergeordneter Prozesse verwendet oder führt Node.js-Moduldateien und ausführbare Dateien aus.

    Cluster-Modul, Cluster-Modul, wird zum Implementieren von Node.js-Anwendungen verwendet. Öffnen Sie mehrere untergeordnete Prozesse, und jeder untergeordnete Prozess führt eine Kopie der Node.js-Anwendung zur Verarbeitung aus , Binärdaten behandeln.
  • child_process.exec(): geeignet für kleine Datenmengen. Der Standardwert von maxBuffer ist 200 * 1024. Das Überschreiten dieses Standardwerts führt zum Absturz des Programms gebraucht.
  • child_process.execFile(): Ähnlich wie child_process.exec() besteht der Unterschied darin, dass es nicht über die Shell ausgeführt werden kann und keine Verhaltensweisen wie E/A-Umleitung und Dateisuche unterstützt

child_process.fork (): Derivate Neue Prozesse sind unabhängig voneinander. Die Systemressourcen sind begrenzt. Es wird nicht empfohlen, zu viele untergeordnete Prozesse zu erzeugen Kerne.

  • Cluster-Modul
  • cluster.fork([env]) startet den untergeordneten Prozess und erstellt eine Instanz der Node.js-Anwendung im untergeordneten Prozess.
  • isMaster-Attribut und isWorker-Attribut werden verwendet Bestimmen Sie, ob im Hauptprozess oder in einem Unterprozess ausgeführt werden soll. Die Worker-Eigenschaft wird verwendet, um die in allen Unterprozessen ausgeführten Worker-Objekte abzurufen. Wie kommunizieren mehrere Threads?
  • Interprozesskommunikation

Vier Typen:

    Nachrichtenübermittlung (Pipeline, FIFO, Nachrichtenwarteschlange)
  • Semaphor (Mutex, Bedingungsvariable, Lese-/Schreibsperre)
  • Gemeinsamer Speicher ( anonym, benannt)
  • Remote Procedure Call

Interprozesskommunikation kommt nicht nur in Node, sondern auch in anderen Sprachen vor. Natürlich ist dies auch eine Frage, die im Vorstellungsgespräch unbedingt gestellt werden muss. Viele Inhalte können ausführlich besprochen werden!

Weitere Kenntnisse zum Thema Programmierung finden Sie unter:

Einführung in die Programmierung
    ! !

Das obige ist der detaillierte Inhalt vonIst Node.js wirklich Single-Threaded? Wie kommuniziert man zwischen Prozessen?. 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)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
1 Monate 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!

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