Einführung in asynchrone Knoten-E/A
Dieser Artikel stellt hauptsächlich die Einführung von Node Asynchronous I/O vor, die einen gewissen Referenzwert hat. Jetzt kann ich ihn mit allen teilen, die ihn benötigen
Asynchronous IO
1. Warum asynchrone E/A verwenden
Benutzererfahrung
Javascript wird in einem einzelnen Thread ausgeführt, der derselbe Thread wie der UI-Thread ist. Wenn Synchronisierung verwendet wird, wird die Benutzeroberfläche ausgeführt Wenn Javascript ausgeführt wird, muss das Rendern angehalten und gewartet werden, was zu einer sehr schlechten Benutzererfahrung führt.
Wenn die Webseite einige Ressourcen anfordern und diese synchron abrufen muss, müssen wir warten, bis js die Ressourcen vollständig vom Server abgerufen hat, bevor wir mit der Ausführung fortfahren. Während dieser Zeit wartet die Benutzeroberfläche, was dazu führt Die Interaktion mit dem Benutzer ist extrem schlecht, was sich auf das Benutzererlebnis auswirkt.
// 现在请求两个资源 //耗时为M毫秒 getData('from_db'); //耗时为N毫秒 getData('from_remote_api');
Wenn es synchron ist, wird es einige Zeit dauern(M + N)
;
Wenn es asynchron ist, wird es einige Zeit dauernMax(M, N)
;
Mit der Komplexität der Anwendung wird die Das Szenario wird zu M+N+...和Max(M,N,...)
Zu diesem Zeitpunkt werden die Vor- und Nachteile von Synchronisation und Asynchronität stärker in den Vordergrund treten. Andererseits werden Daten bei der Erweiterung von Websites und Anwendungen häufig auf mehrere Server verteilt, und die Verteilung bedeutet, dass die Werte von M und N linear wachsen, was auch den Leistungsunterschied zwischen asynchronen und synchronen Daten verstärkt. Kurz gesagt, IO ist teuer und verteiltes IO ist noch teurer!
Ressourcenzuweisung
Single-Threaded synchrones IO
会因阻塞IO使得硬件资源无法得到更优的利用。
Multithread-Programmierung
优点: 可以利用多核CPU有效提升CPU的利用率 缺点: 编程中的死锁、状态同步使得程序员很是头疼。
Asynchrone E/A des Knotens
node采用的异步IO,利用单线程,远离了多线程死锁、状态同步,利用异步让单线程远离了阻塞,使得CPU得到更好的利用。 为了弥补单线程无法利用多核CPU的问题,Node提供了子进程 `childProcess` ,将一些运算多的任务放入子进程进行高效的运算。
2. Blockierende E/A und nicht blockierende E/A
Blockierende E/A
阻塞的IO操作就是发起IO操作后,线程阻塞等待IO完成,这期间cpu得不到有效利用。
Nicht blockierende E/A
非阻塞IO操作其实就是发起IO操作后,通过事件轮巡,或者事件通知机制,不断查询IO操作是否完成,或者是主线程进入休眠等待事件通知IO结束,然后继续向下执行代码,实际上非阻塞IO期间,cpu要不用来查询要不用来休眠,也没有得到有效利用。依旧是同步IO。
3 des Knotens
Ein einzelner Link ist erforderlich, um die gesamte asynchrone E/A abzuschließen事件循环
观察者
请求对象
.
Tatsächlich verwendet die asynchrone E/A des Knotens die Thread-Pool-Technologie. Wenn die asynchrone E/A initiiert wird, wird die IO-Operation zur Ausführung in den Thread-Pool geworfen, und dann führt der Hauptthread weiterhin andere Operationen aus Die Ausführung wird über die Kommunikation zwischen Threads benachrichtigt. Der Hauptthread führt den Rückruf aus.
IO-Thread wird durch den von Libuv
verwalteten Thread-Pool gesteuert (unter Linux
wird durch libeio
implementiert; unter window
wird durch IOCP
implementiert) und ist im Wesentlichen multithreaded. Das heißt, 线程池
und 阻塞IO
werden verwendet, um 异步IO
zu simulieren.
Asynchrones IO-Prinzip
Wenn IO auftritt, legen Sie es in einen IO-Thread im Thread-Pool und lassen Sie die Aufgabe ausführen wird auf dem E/A-Thread ausgeführt, der im blockierenden E/A-Modus ausgeführt wird, und setzt dann die Ausführung auf dem Hauptthread fort. Wenn eine andere E/A-Aufgabe auftritt, wird sie in den Thread-Pool gestellt und dann auf einem anderen E/A-Thread ausgeführt im blockierenden IO-Modus) wird der Hauptthread weiterhin ausgeführt.
Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, er wird für das Studium aller hilfreich sein. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website.
Verwandte Empfehlungen:
Analyse des Node-Modulmechanismus
Das obige ist der detaillierte Inhalt vonEinführung in asynchrone Knoten-E/A. 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

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

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