Heim  >  Artikel  >  Web-Frontend  >  Prinzip und Implementierungsmethode für die gemeinsame Nutzung von Ressourcen für den übergeordneten und untergeordneten Prozess von NodeJS

Prinzip und Implementierungsmethode für die gemeinsame Nutzung von Ressourcen für den übergeordneten und untergeordneten Prozess von NodeJS

亚连
亚连Original
2018-05-29 17:40:231631Durchsuche

In diesem Artikel werden hauptsächlich das Prinzip und die Implementierungsmethode der Ressourcenfreigabe zwischen dem übergeordneten und untergeordneten NodeJS-Prozess vorgestellt und die zugehörigen Betriebsfähigkeiten von NodeJS basierend auf dem Clustermodul analysiert, um die gemeinsame Nutzung von Ressourcen zwischen dem übergeordneten und untergeordneten Prozess zu realisieren Beispiele. Freunde in Not können sich auf Folgendes beziehen:

Die Beispiele in diesem Artikel beschreiben das Prinzip und die Implementierungsmethode der Ressourcenfreigabe zwischen dem übergeordneten NodeJS-Prozess und dem untergeordneten Prozess. Teilen Sie es wie folgt mit allen als Referenz:

Experimentelles Ziel: Ressourcenteilung zwischen übergeordnetem und untergeordnetem Prozess realisieren

Verwenden Sie das Modul: Cluster

Einführung: Erstellen Sie einen Knotencluster und implementieren Sie mehrere Prozesse mithilfe von child_process IPC löst die Multi-Core-Auslastung und verbessert die Leistung.

Prinzip:

1 Multiprozessarchitektur des Master-Worker-Master-Slave-Modus

2 fork()Kopieren Prozess, CPU-Ressourcen voll ausnutzen (bestimmt durch die Anzahl der Kerne)

3 Jeder Prozess hat seinen eigenen Bereich. Wenn Operationen in ihren jeweiligen Bereichen ausgeführt werden, werden Ressourcen nicht gemeinsam genutzt. Durch Abhören des Nachrichtenereignisses und Senden wird die Nachrichtenweitergabe erreicht, um den Effekt der Ressourcenfreigabe zu erzielen

4 globalDataError ist die falsche Methode zur Ressourcenfreigabe und globalDataSuccess ist die richtige Methode zur Ressourcenfreigabe.

Implementierungscode:

var cluster = require('cluster');
var cpus = require('os').cpus();
// 传递的事件名
var triggerEvent = {
    inc: 'inc',
    dec: 'dec'
}
// 错误的数据共享方式
var globalDataError = 0;
if (cluster.isMaster) {
  // 正确的数据共享方式
  var globalDataSuccess = 0;
  globalDataError++;
  // 启动多个进程,取决于内核数
  for (var i = 0; i < cpus.length; i++) {
    var worker = cluster.fork();
    worker.on(&#39;message&#39;, function(msg) {
      switch (msg) {
        case triggerEvent.inc:
          globalDataSuccess++;
          console.log(&#39;globalDataSuccess = &#39;, globalDataSuccess);
          break;
        case triggerEvent.dec:
          globalDataSuccess--;
          console.log(&#39;globalDataSuccess = &#39;, globalDataSuccess);
          break;
      }
    });
  }
  console.log(&#39;Master globalDataError = &#39;, globalDataError);
} else {
  globalDataError++;
  console.log(&#39;Worker globalDataError = &#39;, globalDataError);
  process.send(triggerEvent.dec);
  process.send(triggerEvent.inc);
}

Das Obige habe ich für alle zusammengestellt. Ich hoffe, dass es in Zukunft für alle hilfreich sein wird.

Verwandte Artikel:

Lösung für das Flash-Problem beim Laden von Vue-Seiten

Eine kurze Diskussion über das Problem, dass js ModelAndView erhält Wert

Das Problem und die Lösung des Flackerns von {{}} beim Rendern von Vue

Das obige ist der detaillierte Inhalt vonPrinzip und Implementierungsmethode für die gemeinsame Nutzung von Ressourcen für den übergeordneten und untergeordneten Prozess von NodeJS. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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