Node.js - Skalierungsanwendung

Node.js wird in einem Single-Thread-Modus ausgeführt, verwendet jedoch ein ereignisgesteuertes Paradigma, um die Parallelität zu verarbeiten. Es erleichtert auch die Erstellung untergeordneter Prozesse, um die parallele Verarbeitung auf mehrkernigen CPU-basierten Systemen zu nutzen.

Untergeordnete Prozesse haben immer drei Streams child.stdin, child.stdout, und child.stderr Dies kann mit den Standard-Streams des übergeordneten Prozesses geteilt werden.

Knoten bietet child_process Modul mit den folgenden drei Hauptmethoden zum Erstellen eines untergeordneten Prozesses.

  • exec - Die child_process.exec-Methode führt einen Befehl in einer Shell / Konsole aus und puffert die Ausgabe.

  • spawn - child_process.spawn startet einen neuen Prozess mit einem bestimmten Befehl.

  • fork - Die child_process.fork-Methode ist ein Sonderfall von spawn () zum Erstellen untergeordneter Prozesse.

Die exec () -Methode

Die Methode child_process.exec führt einen Befehl in einer Shell aus und puffert die Ausgabe. Es hat die folgende Signatur -

child_process.exec(command[, options], callback)

Parameter

Hier ist die Beschreibung der verwendeten Parameter -

  • command (String) Der auszuführende Befehl mit durch Leerzeichen getrennten Argumenten

  • options (Objekt) kann eine oder mehrere der folgenden Optionen umfassen:

    • cwd (String) Aktuelles Arbeitsverzeichnis des untergeordneten Prozesses

    • env (Objekt-) Umgebungsschlüssel-Wert-Paare

    • encoding (String) (Standard: 'utf8')

    • shell (String) Shell zum Ausführen des Befehls mit (Standard: '/ bin / sh' unter UNIX, 'cmd.exe' unter Windows. Die Shell sollte den Schalter -c unter UNIX oder / s / c unter Windows verstehen. Unter Windows, Das Parsen der Befehlszeile sollte mit cmd.exe kompatibel sein.)

    • timeout (Nummer) (Standard: 0)

    • maxBuffer (Anzahl) (Standard: 200 * 1024)

    • killSignal (String) (Standard: 'SIGTERM')

    • uid (Nummer) Legt die Benutzeridentität des Prozesses fest.

    • gid (Nummer) Legt die Gruppenidentität des Prozesses fest.

  • callback Die Funktion erhält drei Argumente error, stdout, und stderr die mit der Ausgabe aufgerufen werden, wenn der Prozess beendet wird.

Die exec () -Methode gibt einen Puffer mit einer maximalen Größe zurück und wartet auf das Ende des Prozesses und versucht, alle gepufferten Daten auf einmal zurückzugeben.

Beispiel

Lassen Sie uns zwei js-Dateien mit den Namen support.js und master.js erstellen -

File: support.js

console.log("Child Process " + process.argv[2] + " executed." );

File: master.js

const fs = require('fs');
const child_process = require('child_process');

for(var i=0; i<3; i++) {
   var workerProcess = child_process.exec('node support.js '+i,function 
      (error, stdout, stderr) {
      
      if (error) {
         console.log(error.stack);
         console.log('Error code: '+error.code);
         console.log('Signal received: '+error.signal);
      }
      console.log('stdout: ' + stdout);
      console.log('stderr: ' + stderr);
   });

   workerProcess.on('exit', function (code) {
      console.log('Child process exited with exit code '+code);
   });
}

Führen Sie nun die Datei master.js aus, um das Ergebnis anzuzeigen.

$ node master.js

Überprüfen Sie die Ausgabe. Server wurde gestartet.

Child process exited with exit code 0
stdout: Child Process 1 executed.

stderr:
Child process exited with exit code 0
stdout: Child Process 0 executed.

stderr:
Child process exited with exit code 0
stdout: Child Process 2 executed.

Die spawn () Methode

Die Methode child_process.spawn startet einen neuen Prozess mit einem bestimmten Befehl. Es hat die folgende Signatur -

child_process.spawn(command[, args][, options])

Parameter

Hier ist die Beschreibung der verwendeten Parameter -

  • command (String) Der auszuführende Befehl

  • args (Array) Liste der Zeichenfolgenargumente

  • options (Objekt) kann eine oder mehrere der folgenden Optionen umfassen:

    • cwd (String) Aktuelles Arbeitsverzeichnis des untergeordneten Prozesses.

    • env (Objekt-) Umgebungsschlüssel-Wert-Paare.

    • stdio (Array) String Die Standardkonfiguration des Kindes.

    • customFds (Array) Veraltete Dateideskriptoren, die das Kind für stdio verwenden kann.

    • detached (Boolean) Das Kind wird ein Prozessgruppenleiter sein.

    • uid (Nummer) Legt die Benutzeridentität des Prozesses fest.

    • gid (Nummer) Legt die Gruppenidentität des Prozesses fest.

Die spawn () -Methode gibt Streams (stdout & stderr) zurück und sollte verwendet werden, wenn der Prozess eine Datenmenge zurückgibt. spawn () empfängt die Antwort, sobald der Prozess ausgeführt wird.

Beispiel

Erstellen Sie zwei js-Dateien mit den Namen support.js und master.js -

File: support.js

console.log("Child Process " + process.argv[2] + " executed." );

File: master.js

const fs = require('fs');
const child_process = require('child_process');
 
for(var i = 0; i<3; i++) {
   var workerProcess = child_process.spawn('node', ['support.js', i]);

   workerProcess.stdout.on('data', function (data) {
      console.log('stdout: ' + data);
   });

   workerProcess.stderr.on('data', function (data) {
      console.log('stderr: ' + data);
   });

   workerProcess.on('close', function (code) {
      console.log('child process exited with code ' + code);
   });
}

Führen Sie nun die Datei master.js aus, um das Ergebnis anzuzeigen.

$ node master.js

Überprüfen Sie die Ausgabe. Server wurde gestartet

stdout: Child Process 0 executed.

child process exited with code 0
stdout: Child Process 1 executed.

stdout: Child Process 2 executed.

child process exited with code 0
child process exited with code 0

Die fork () -Methode

Die child_process.fork-Methode ist ein Sonderfall von spawn () zum Erstellen von Knotenprozessen. Es hat die folgende Signatur -

child_process.fork(modulePath[, args][, options])

Parameter

Hier ist die Beschreibung der verwendeten Parameter -

  • modulePath (String) Das Modul, das im untergeordneten Element ausgeführt werden soll.

  • args (Array) Liste der Zeichenfolgenargumente

  • options (Objekt) kann eine oder mehrere der folgenden Optionen umfassen:

    • cwd (String) Aktuelles Arbeitsverzeichnis des untergeordneten Prozesses.

    • env (Objekt-) Umgebungsschlüssel-Wert-Paare.

    • execPath (String) Ausführbare Datei, die zum Erstellen des untergeordneten Prozesses verwendet wird.

    • execArgv (Array) Liste der an die ausführbare Datei übergebenen Zeichenfolgenargumente (Standard: process.execArgv).

    • silent (Boolean) Wenn true, werden stdin, stdout und stderr des Kindes an das übergeordnete Element weitergeleitet, andernfalls werden sie vom übergeordneten Element geerbt. Weitere Informationen finden Sie in den Optionen "pipe" und "erben" für das stdio von spawn () Details (Standard ist false).

    • uid (Nummer) Legt die Benutzeridentität des Prozesses fest.

    • gid (Nummer) Legt die Gruppenidentität des Prozesses fest.

Die Fork-Methode gibt ein Objekt mit einem integrierten Kommunikationskanal zurück und verfügt außerdem über alle Methoden in einer normalen ChildProcess-Instanz.

Beispiel

Erstellen Sie zwei js-Dateien mit den Namen support.js und master.js -

File: support.js

console.log("Child Process " + process.argv[2] + " executed." );

File: master.js

const fs = require('fs');
const child_process = require('child_process');
 
for(var i=0; i<3; i++) {
   var worker_process = child_process.fork("support.js", [i]);	

   worker_process.on('close', function (code) {
      console.log('child process exited with code ' + code);
   });
}

Führen Sie nun die Datei master.js aus, um das Ergebnis anzuzeigen.

$ node master.js

Überprüfen Sie die Ausgabe. Server wurde gestartet.

Child Process 0 executed.
Child Process 1 executed.
Child Process 2 executed.
child process exited with code 0
child process exited with code 0
child process exited with code 0