node.js ist standardmäßig Single-Threaded, Node.js verwendet jedoch einen Single-Threaded-asynchronen, nicht blockierenden Modus -Threading-Unterstützung. Es ist nur so, dass der Hauptthread Single-Threaded ist und Vorgänge im Hauptthread synchron blockiert werden.
Die Betriebsumgebung dieses Tutorials: Windows 10-System, NodeJS-Version 12.19.0, Dell G3-Computer.
node.js ist standardmäßig Single-Threaded und node.js verwendet den Single-Threaded-asynchronen, nicht blockierenden Modus.
node.js verwendet den asynchronen, nicht blockierenden Single-Threaded-Modus. Sein einzelner Thread bezieht sich auf den einzelnen Thread seiner eigenen Javascript-Laufumgebung. Node.js verfügt nicht über die Fähigkeit, neue Threads zu erstellen, wenn Javascript über Libuv und seine Ereignisschleife ausgeführt wird.
Knoten bedeutet nur, dass der Hauptthread ein Single-Thread ist und die Vorgänge im Hauptthread synchron blockiert sind. Es wirft jedoch alle asynchronen Vorgänge in den E/A-Thread-Pool, und der Hauptthread interagiert mit dem E/A-Thread-Pool über einen bestimmten Ereignisabfragemechanismus, um asynchrone Daten zu erhalten.
Die Leistung von node.js ist nicht die höchste. Aufgrund der JavaScript-Engine ist node.js standardmäßig Single-Threaded und eine node.js-Anwendung kann keine Multi-Core-Ressourcen nutzen.
Es gibt jedoch Bibliotheken von Drittanbietern, die Multithreading-Unterstützung bieten, diese ist jedoch nicht nahtlos. Node.js löst E/A-Engpässe (im Vergleich zur herkömmlichen Technologie verschwenden synchrone Blockierungsaufrufe keine Threads, aber die Ressourcenplanung ist effizienter). Wenn die E/A-Geschwindigkeit nicht gelöst ist, kann node.js nur sagen, dass es viele Anfragen gleichzeitig verarbeiten kann, aber die Antwortzeit jeder Anfrage ist immer noch so lang oder sogar länger.
Knoten ist Single-Threaded. Wie geht er also mit vielen gleichzeitigen Anfragen um?
Setzen Sie auf ereignisgesteuert.
Jeder Node.js-Prozess verfügt nur über einen Hauptthread, der Programmcode ausführt und so einen Ausführungskontextstapel bildet.
Zusätzlich zum Hauptthread wird auch eine „Ereigniswarteschlange“ gepflegt. Wenn die Netzwerkanforderung oder ein anderer asynchroner Vorgang des Benutzers eintrifft, stellt der Knoten ihn in die Ereigniswarteschlange. Zu diesem Zeitpunkt wird er nicht sofort ausgeführt und der Code wird nicht blockiert. Er wird fortgesetzt, bis der Haupt-Thread-Code ausgeführt wird. vollständig.
Nachdem die Ausführung des Haupt-Thread-Codes abgeschlossen ist und dann über die Ereignisschleife, d. h. den Ereignisschleifenmechanismus, das erste Ereignis vom Anfang der Ereigniswarteschlange abgerufen wird, wird ein Thread aus dem Thread-Pool zugewiesen Führen Sie dieses Ereignis aus und fahren Sie dann mit dem Abrufen des dritten Ereignisses fort. Für das zweite Ereignis wird ein Thread aus dem Thread-Pool zur Ausführung zugewiesen, dann der dritte und der vierte. Der Hauptthread prüft kontinuierlich, ob nicht ausgeführte Ereignisse in der Ereigniswarteschlange vorhanden sind, bis alle Ereignisse in der Ereigniswarteschlange ausgeführt wurden. Danach wird der Hauptthread benachrichtigt, wenn ein neues Ereignis zur Ereigniswarteschlange hinzugefügt wird bestellen und zur Bearbeitung an EventLoop übergeben. Wenn ein Ereignis ausgeführt wird, wird der Hauptthread benachrichtigt, der Hauptthread führt den Rückruf aus und der Thread wird an den Thread-Pool zurückgegeben.
Der Hauptthread wiederholt den dritten Schritt oben immer wieder.
Der einzelne Thread von NodeJ ist lediglich ein Hauptthread. Der Thread-Pool übergibt alle blockierenden Vorgänge zur Implementierung. Er ist nur für die kontinuierliche Roundtrip-Planung verantwortlich Echte E/A-Operationen, wodurch asynchrone, nicht blockierende E/A erreicht werden. Dies ist die Essenz des Single-Thread- und ereignisgesteuerten Knotens.
Empfohlenes Lernen: „nodejs-Video-Tutorial“
Das obige ist der detaillierte Inhalt vonIst node.js Single-Threaded?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!