Heim Web-Frontend js-Tutorial Wie NodeJS mit intensiven Berechnungen umgeht

Wie NodeJS mit intensiven Berechnungen umgeht

Apr 18, 2020 am 09:51 AM
nodejs

Wie NodeJS mit intensiven Berechnungen umgeht

Wie gehen NodeJS mit intensiven Berechnungen um?

Nodejs-intensive CPU-Lösung

Lassen Sie uns zunächst über die Vorteile von Nodejs Single Thread sprechen:

Empfohlen: "Javascript Advanced Tutorial

Hohe Leistung: Im Vergleich zu PHP vermeidet es den Aufwand für das häufige Erstellen und Wechseln von Threads, führt schneller aus und beansprucht weniger Ressourcen.

Thread-sicher, Sie müssen sich keine Sorgen machen, dass dieselbe Variable von mehreren Threads gelesen und geschrieben wird und das Programm abstürzt.

Single-Threaded asynchron und non-blocking Tatsächlich sind die zugrunde liegenden Nodejs-Zugriffs-E/A Multithreading/nicht-blockierend und asynchron/synchronisierend. Aber das Blockieren ist auf jeden Fall etwas kompliziert. Bitte geben Sie mir ein Beispiel: Ich habe mich für Set A entschieden, und dann hat mir das Personal beim Zubereiten des Essens geholfen Damit das Personal das Essen für mich zubereiten kann, wäre diese Situation so: Wenn das Personal mir beim Zubereiten des Essens hilft, beginnen die Leute hinter mir mit der Bestellung, sodass der Bestellservice in der gesamten Kantine nicht aufhört, weil ich es bin Warten auf Satz A. Diese Situation wird als nicht blockierend bezeichnet. Dieses Beispiel veranschaulicht lediglich die synchrone, aber nicht blockierende Situation. Wenn ich außerdem ein Getränk kaufe, während ich auf das Essen warte, und dann zurückgehe, um das festgelegte Essen zu holen, wenn meine Nummer angerufen wird, wurde mein Getränk bereits gekauft. Auf diese Weise warte ich auf das Essen bedient werden, erledige ich auch die Aufgabe, ein Getränk zu kaufen. Das Anrufen der Nummer entspricht Sobald der Rückruf ausgeführt wird, erfolgt er asynchron und nicht blockierend. Wenn beim Kauf eines Getränks meine Nummer angerufen wurde, damit ich die festgelegte Mahlzeit erhalten kann, ich aber lange auf das Getränk warten muss, kann es sein, dass ich die festgelegte Mahlzeit A erst lange nach der Nummer meiner Mahlzeit erhalte Rufen Sie die Lobby auf, was bedeutet, dass ein einzelner Thread blockiert ist.

Multi-Threading:

Thread ist eine Grundeinheit der CPU-Planung. Eine CPU kann nur eine Thread-Aufgabe ausführen.

Nodejs können auch Multithread-Aufgaben ausführen, z. B. das Referenzieren des TAGG/TAGG2-Moduls, aber sowohl tagg/tagg2 verwenden die pthread-Bibliothek als auch die V8::Isolate-Klasse, um die js-Multithreading-Funktion zu implementieren Gemäß den Regeln können wir in Threads ausgeführte Funktionen nicht die Kern-API von NodeJS wie FS- und Krypto-Module verwenden, daher gibt es immer noch große Einschränkungen.

Mehrere Prozesse:

In Browsern, die HTML5 unterstützen, können wir Webworker verwenden, um einige zeitaufwändige Berechnungen zur Ausführung in den Arbeitsprozess zu werfen, sodass der Hauptprozess nicht blockiert wird und der Benutzer Es wird kein Verzögerungsgefühl geben.

Hier müssen wir das child_process-Modul von nodejs verwenden, das die Fork-Methode bereitstellt, die eine nodejs-Datei starten und sie als Worker-Prozess betrachten kann, an den das Ergebnis gesendet wird Der Hauptprozess wird beendet, und der Worker wird dann automatisch beendet, sodass wir mehrere Prozesse verwenden können, um das Problem der Blockierung des Hauptthreads zu lösen.

var express = require('express');
var fork = require('child_process').fork;
var app = express();
app.get('/', function(req, res){
  var worker = fork('./work.js') //创建一个工作进程
  worker.on('message', function(m) {//接收工作进程计算结果
          if('object' === typeof m && m.type === 'fibo'){
                   worker.kill();//发送杀死进程的信号
                   res.send(m.result.toString());//将结果返回客户端
          }
  });
  worker.send({type:'fibo',num:~~req.query.n || 1});
  //发送给工作进程计算fibo的数量
});
app.listen(7878);
Nach dem Login kopieren

Wir lauschen Port 7878 über Express. Für jede Benutzeranforderung forken wir einen untergeordneten Prozess, übergeben den Parameter n an den untergeordneten Prozess, indem wir die Methode worker.send aufrufen und gleichzeitig abhören Das Nachrichtenereignis der vom untergeordneten Prozess gesendeten Nachricht antwortet dem Client mit dem Ergebnis.

Das Folgende ist der Inhalt der gespaltenen Datei work.js:

var fibo = function fibo (n) {//定义算法
   return n > 1 ? fibo(n - 1) + fibo(n - 2) : 1;
}
process.on('message', function(m) {
//接收主进程发送过来的消息
          if(typeof m === 'object' && m.type === 'fibo'){
                  var num = fibo(~~m.num);
                  //计算jibo
                  process.send({type: 'fibo',result:num})
                  //计算完毕返回结果       
          }
});
process.on('SIGHUP', function() {
        process.exit();//收到kill信息,进程退出
});
Nach dem Login kopieren

Wir definieren zuerst die Funktion fibo, um das Fibonacci-Array zu berechnen, und hören dann die vom Hauptthread gesendeten Nachrichten ab. Die Berechnung ist abgeschlossen. Senden Sie dann das Ergebnis an den Hauptthread. Gleichzeitig lauscht es auch auf das SIGHUP-Ereignis des Prozesses. Wenn dieses Ereignis ausgelöst wird, wird der Prozess beendet.

Eine Sache, die wir hier beachten müssen, ist, dass die Kill-Methode des Hauptthreads nicht tatsächlich zum Beenden des untergeordneten Prozesses führt, sondern das SIGHUP-Ereignis des untergeordneten Prozesses auslöst. Der eigentliche Ausgang hängt immer noch vom Prozess ab. Ausfahrt().

Zusammenfassung:

Die Verwendung der Fork-Methode des child_process-Moduls kann es uns tatsächlich ermöglichen, das Blockierungsproblem von Single-Threaded-CPU-intensiven Aufgaben zu lösen, aber gleichzeitig ist dies unmöglich Verwenden Sie Node.js ohne das Tagg-Paket. Einschränkungen der Kern-API.

Asynchrones Node.js mit einem Thread bedeutet nicht, dass es nicht blockiert, wenn zu viele Aufgaben im Hauptthread ausgeführt werden, was dazu führen kann, dass der Hauptthread hängen bleibt und die Leistung des gesamten Programms beeinträchtigt wird Seien Sie bei der Bearbeitung einer großen Anzahl von Aufgaben sehr vorsichtig, z. B. Schleifen, String-Splicing und Gleitkommaoperationen. Es ist sinnvoll, verschiedene Technologien zu verwenden, um Aufgaben Sub-Threads oder Sub-Prozessen zuzuordnen, die ausgeführt werden sollen Node.js Hauptthread geöffnet.

Die Verwendung von Threads/Prozessen ist nicht ohne Overhead. Wenn Sie die Anzahl der Erstellung und Zerstörung von Threads/Prozessen so weit wie möglich reduzieren, können Sie die Gesamtleistung und Fehlerwahrscheinlichkeit unseres Systems verbessern.

Das obige ist der detaillierte Inhalt vonWie NodeJS mit intensiven Berechnungen umgeht. 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)

Der Unterschied zwischen NodeJS und VueJS Der Unterschied zwischen NodeJS und VueJS Apr 21, 2024 am 04:17 AM

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.

Ist NodeJS ein Backend-Framework? Ist NodeJS ein Backend-Framework? Apr 21, 2024 am 05:09 AM

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.

So verbinden Sie NodeJS mit der MySQL-Datenbank So verbinden Sie NodeJS mit der MySQL-Datenbank Apr 21, 2024 am 06:13 AM

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.

Was ist der Unterschied zwischen den Dateien npm und npm.cmd im Installationsverzeichnis von nodejs? Was ist der Unterschied zwischen den Dateien npm und npm.cmd im Installationsverzeichnis von nodejs? Apr 21, 2024 am 05:18 AM

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.

Was sind die globalen Variablen in NodeJS? Was sind die globalen Variablen in NodeJS? Apr 21, 2024 am 04:54 AM

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

Gibt es einen großen Unterschied zwischen NodeJS und Java? Gibt es einen großen Unterschied zwischen NodeJS und Java? Apr 21, 2024 am 06:12 AM

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.

Ist NodeJS eine Back-End-Entwicklungssprache? Ist NodeJS eine Back-End-Entwicklungssprache? Apr 21, 2024 am 05:09 AM

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.

So stellen Sie das NodeJS-Projekt auf dem Server bereit So stellen Sie das NodeJS-Projekt auf dem Server bereit Apr 21, 2024 am 04:40 AM

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

See all articles