Inhaltsverzeichnis
Asynchronous IO
1. Warum asynchrone E/A verwenden
3 des Knotens
Heim Web-Frontend js-Tutorial Einführung in asynchrone Knoten-E/A

Einführung in asynchrone Knoten-E/A

Jul 11, 2018 pm 03:44 PM
node.js

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');
Nach dem Login kopieren

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使得硬件资源无法得到更优的利用。
Nach dem Login kopieren

Multithread-Programmierung

优点: 可以利用多核CPU有效提升CPU的利用率
缺点: 编程中的死锁、状态同步使得程序员很是头疼。
Nach dem Login kopieren

Asynchrone E/A des Knotens

node采用的异步IO,利用单线程,远离了多线程死锁、状态同步,利用异步让单线程远离了阻塞,使得CPU得到更好的利用。

为了弥补单线程无法利用多核CPU的问题,Node提供了子进程 `childProcess` ,将一些运算多的任务放入子进程进行高效的运算。
Nach dem Login kopieren

Einführung in asynchrone Knoten-E/A

2. Blockierende E/A und nicht blockierende E/A

Blockierende E/A

阻塞的IO操作就是发起IO操作后,线程阻塞等待IO完成,这期间cpu得不到有效利用。
Nach dem Login kopieren

Einführung in asynchrone Knoten-E/A

Nicht blockierende E/A

非阻塞IO操作其实就是发起IO操作后,通过事件轮巡,或者事件通知机制,不断查询IO操作是否完成,或者是主线程进入休眠等待事件通知IO结束,然后继续向下执行代码,实际上非阻塞IO期间,cpu要不用来查询要不用来休眠,也没有得到有效利用。依旧是同步IO。
Nach dem Login kopieren

Einführung in asynchrone Knoten-E/A

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.

Einführung in asynchrone Knoten-E/A

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!

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

Video Face Swap

Video Face Swap

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

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