Implementieren Sie die Blockierungsinstanz in nodejs_node.js
Der in node.js inhärente asynchrone Stil der Single-Thread-Programmierung und Rückruffunktion macht uns manchmal glücklich und manchmal besorgt. Lassen Sie uns zunächst über Single-Threading sprechen. Viele Leute fragen sich, wie der Single-Thread von node.js eine hohe Parallelität erreichen kann. Dieses Problem steht nicht im Mittelpunkt dieses Artikels, also lassen Sie uns hier aufhören. Zur Verdeutlichung: Der einzelne Thread von node.js bezieht sich nur auf die Single-Threaded-JavaScript-Engine. Wir haben jedoch keine Möglichkeit, Multithreading und Blockierung in JavaScript zu implementieren (die in diesem Artikel verwendete Methode wird auch nicht durch synchronisiert). V8-Engine), aber für Knoten. Andere Aspekte von .js bedeuten nicht, dass es nicht multithreadbar ist, wie z. B. IO. Wenn node.js nun einer großen Anzahl von Anforderungen ausgesetzt ist und diese Anforderungen E/A-intensiv sind, wartet der Javascript-Thread nicht immer hier, wenn er auf eine lange E/A-Operation stößt, sondern übergibt die Kontrolle und Fügen Sie die Operationen hinzu, die nach Abschluss der E/A-Operation im Rückrufstapel ausgeführt werden sollen (wenn zu viele Rückrufebenen vorhanden sind und die Anzahl der Zugriffe zu groß ist, kann eine große Anzahl von Rückrufketten den Stapel platzen lassen). Während dieser Zeit kann node.js andere Anfragen bearbeiten. Obwohl Javascript Single-Threaded ist und jeweils nur eine Anfrage verarbeiten kann, ist die Zeit, die Javascript für die Verarbeitung einer Anfrage benötigt, oft kürzer (für IO-intensive Anwendungen, solange es verarbeitet werden kann). asynchron, dann während der Verarbeitung gibt diese Anforderung die Kontrolle frei, sodass node.js andere Anforderungen verarbeiten kann. Während dieser gleichzeitigen Anforderung befindet sich E/A tatsächlich immer in einem gleichzeitigen Zustand, wodurch die Anzahl der Threads, die Anforderungen verarbeiten, reduziert und Ressourcen gespart werden, um die Anzahl der E/A-Threads zu erhöhen, die normalerweise lange dauern, was zweifellos zu Leistungsverbesserungen führt . fördern.
Ich habe in der Vergangenheit die IO-Intensität betont, aber eigentlich betone ich die Stärken von node.js. Dementsprechend besteht sein Manko in CPU-intensiven Anfragen. Der Grund ist sehr einfach: JavaScript ist nicht gleichzeitig und andere Anforderungen können erst verarbeitet werden, nachdem eine Anforderung abgeschlossen ist. Je länger die Bearbeitung einer Anfrage dauert, desto länger müssen andere Anfragen warten. Es wird jeweils nur eine Anfrage verarbeitet und die Parallelitätsleistung ist sehr gering.
Allerdings möchte ich klarstellen: node.js sollte nicht blockiert werden; Methoden, die asynchron verarbeitet werden können, werden asynchron verarbeitet (z. B. die Verwendung von fs.readFile() anstelle von fs.syncReadFile() fs.readFileSync ()-Methode).
Kann im Knoten nicht blockiert werden. Dies bedeutet nicht, dass es nicht außerhalb des Knotens blockiert werden kann. Wir haben vorhin über Fasern gesprochen. Versuchen wir nun, die Blockierung in Fasern umzusetzen. Nehmen wir als Beispiel die Verarbeitung einer http-Anfrage:
var Fiber = require('fibers');
var http = require("http");
Fiber(function () {
var httpFiber = Fiber.current;
var html = "";
http.get("http://www.baidu.com", Funktion (res) {
var dataFiber = Fiber.current;
res.on("data", function (data) {
html = data;
});
res.on("end", Funktion (Daten) {
httpFiber.run();
});
});
Fiber.yield();
console.log(html);
}).run();
yield() und run() nicht vertraut sind, überprüfen Sie bitte selbst „Fasern im Knoten“.
Fasern laufen nicht im Knotenprozess, daher hat das Blockieren innerhalb von Fasern keinen Einfluss auf die Gesamtleistung des Knotens. Und es ist ganz einfach umzusetzen. Sie müssen die Faser nur dann nachgeben, wenn Sie blockieren möchten. Wenn Sie die Ausführung fortsetzen müssen, führen Sie run() aus, um die Fiber wiederherzustellen. Im obigen Beispiel möchten wir das aktuelle Programm blockieren, wenn die http.get-Anfrage initiiert wird, und das Programm fortsetzen, wenn der gesamte Datenempfang abgeschlossen ist. Daher verwenden wir Fiber.yield(), um diese Faser nach dem Aufruf von http.get zu unterbrechen. Wenn bei der Überwachung der Antwort das Endereignis ausgelöst wird, bedeutet dies, dass die Datenübertragung abgeschlossen ist. Rufen Sie daher in der End-Callback-Funktion Fiber.current.run() auf, um die Fiber wiederherzustellen. Auf diese Weise wird der nachfolgende Code abgerufen http.get auf synchrone Weise.
Das obige Beispiel dient nur zur Veranschaulichung. Wenn Sie diese Idee abstrakt kapseln, führen Sie beispielsweise ein einstufiges Currying für eine asynchrone Methode durch, die eine Rückruffunktion als Parameter akzeptiert, unterbrechen Sie sie nach dem Aufruf und kapern Sie die Rückruffunktion, um den Programmcode als Rückruf wiederherzustellen Funktion. Nach Erhalt der asynchronen Daten löst das Programm die vorgegebene Rückruffunktion aus, mit der grundsätzlich die Synchronisation der asynchronen Methode realisiert werden kann. Dieser Absatz ist ziemlich verwirrend, aber im Grunde handelt es sich um die Implementierungsidee von Fibers/Future. Wenn Sie interessiert sind, lesen Sie bitte den Quellcode.

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



Node.js ist eine serverseitige JavaScript-Laufzeitumgebung, während Vue.js ein clientseitiges JavaScript-Framework zum Erstellen interaktiver Benutzeroberflächen ist. Node.js wird für die serverseitige Entwicklung verwendet, beispielsweise für die Entwicklung von Back-End-Service-APIs und die Datenverarbeitung, während Vue.js für die clientseitige Entwicklung verwendet wird, beispielsweise für Single-Page-Anwendungen und reaktionsfähige Benutzeroberflächen.

Node.js kann als Backend-Framework verwendet werden, da es Funktionen wie hohe Leistung, Skalierbarkeit, plattformübergreifende Unterstützung, ein umfangreiches Ökosystem und einfache Entwicklung bietet.

Um eine Verbindung zu einer MySQL-Datenbank herzustellen, müssen Sie die folgenden Schritte ausführen: Installieren Sie den MySQL2-Treiber. Verwenden Sie mysql2.createConnection(), um ein Verbindungsobjekt zu erstellen, das die Hostadresse, den Port, den Benutzernamen, das Passwort und den Datenbanknamen enthält. Verwenden Sie „connection.query()“, um Abfragen durchzuführen. Verwenden Sie abschließend Connection.end(), um die Verbindung zu beenden.

Die folgenden globalen Variablen sind in Node.js vorhanden: Globales Objekt: global Kernmodul: Prozess, Konsole, erforderlich Laufzeitumgebungsvariablen: __dirname, __filename, __line, __column Konstanten: undefiniert, null, NaN, Infinity, -Infinity

Es gibt zwei npm-bezogene Dateien im Node.js-Installationsverzeichnis: npm und npm.cmd. Die Unterschiede sind wie folgt: unterschiedliche Erweiterungen: npm ist eine ausführbare Datei und npm.cmd ist eine Befehlsfensterverknüpfung. Windows-Benutzer: npm.cmd kann über die Eingabeaufforderung verwendet werden, npm kann nur über die Befehlszeile ausgeführt werden. Kompatibilität: npm.cmd ist spezifisch für Windows-Systeme, npm ist plattformübergreifend verfügbar. Nutzungsempfehlungen: Windows-Benutzer verwenden npm.cmd, andere Betriebssysteme verwenden npm.

Die Hauptunterschiede zwischen Node.js und Java sind Design und Funktionen: Ereignisgesteuert vs. Thread-gesteuert: Node.js ist ereignisgesteuert und Java ist Thread-gesteuert. Single-Threaded vs. Multi-Threaded: Node.js verwendet eine Single-Threaded-Ereignisschleife und Java verwendet eine Multithread-Architektur. Laufzeitumgebung: Node.js läuft auf der V8-JavaScript-Engine, während Java auf der JVM läuft. Syntax: Node.js verwendet JavaScript-Syntax, während Java Java-Syntax verwendet. Zweck: Node.js eignet sich für I/O-intensive Aufgaben, während Java für große Unternehmensanwendungen geeignet ist.

Ja, Node.js ist eine Backend-Entwicklungssprache. Es wird für die Back-End-Entwicklung verwendet, einschließlich der Handhabung serverseitiger Geschäftslogik, der Verwaltung von Datenbankverbindungen und der Bereitstellung von APIs.

Serverbereitstellungsschritte für ein Node.js-Projekt: Bereiten Sie die Bereitstellungsumgebung vor: Erhalten Sie Serverzugriff, installieren Sie Node.js, richten Sie ein Git-Repository ein. Erstellen Sie die Anwendung: Verwenden Sie npm run build, um bereitstellbaren Code und Abhängigkeiten zu generieren. Code auf den Server hochladen: über Git oder File Transfer Protocol. Abhängigkeiten installieren: Stellen Sie eine SSH-Verbindung zum Server her und installieren Sie Anwendungsabhängigkeiten mit npm install. Starten Sie die Anwendung: Verwenden Sie einen Befehl wie node index.js, um die Anwendung zu starten, oder verwenden Sie einen Prozessmanager wie pm2. Konfigurieren Sie einen Reverse-Proxy (optional): Verwenden Sie einen Reverse-Proxy wie Nginx oder Apache, um den Datenverkehr an Ihre Anwendung weiterzuleiten
