Heim >Web-Frontend >js-Tutorial >Erlernen des Clustermoduls in Node
In diesem Artikel wird hauptsächlich das Cluster-Modul von Node Learning Record vorgestellt. Der Inhalt ist ziemlich gut und ich werde ihn jetzt als Referenz verwenden.
Im Kontext heutiger Maschinen mit Multi-Core-CPUs kann das Single-Threaded-Design von Node die Maschinenleistung nicht mehr vollständig „quetschen“. Daher hat Node ab Version 0.8 ein integriertes Modul hinzugefügt – „Cluster“, daher der Name. Es kann die Cluster-Funktion realisieren, indem es eine Reihe untergeordneter Prozesse über einen übergeordneten Prozess verwaltet.
var cluster = require('cluster'); var http = require('http'); var numCPUs = require('os').cpus().length; // 获取CPU的个数 if (cluster.isMaster) { for (var i = 0; i < numCPUs; i++) { cluster.fork(); } cluster.on('exit', function(worker, code, signal) { console.log('worker ' + worker.process.pid + ' died'); }); } else { http.createServer(function(req, res) { res.writeHead(200); res.end("hello world\n"); }).listen(8000); }
Verwenden Sie das isMaster-Attribut, um zu bestimmen, ob es sich um den Master-Prozess handelt. Wenn ja, forken Sie den untergeordneten Prozess, andernfalls starten Sie einen Server. Jeder HTTP-Server kann denselben Port abhören. In tatsächlichen Projekten ist unser Startcode jedoch im Allgemeinen in app.js gekapselt. Andernfalls ist es nicht elegant, die gesamte Startlogik in das Obige einzubetten. Wir können also Folgendes tun:
var cluster = require('cluster'); var numCPUs = require('os').cpus().length; if (cluster.isMaster) { for (var i = 0; i < numCPUs; i++) { cluster.fork(); } // 其它代码 } else { require("./app.js"); }
Die Einfachheit besteht darin, dass die ursprüngliche Anwendungslogik nicht wissen muss, ob sie sich in einem Cluster oder einseitig befindet. (Wenn die Anwendung bestimmte Zustände im Speicher beibehält, z. B. Sitzungen, muss sie natürlich einen Mechanismus verwenden, um diese zu teilen. Ich werde hier nicht auf Details eingehen.)
Das Obige ist das Ganze Der Inhalt dieses Artikels wird für alle hilfreich sein. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website.
Verwandte Empfehlungen:
Wie NodeJS das asynchrone Bigpipe-Laden von Seiten implementiert
Das obige ist der detaillierte Inhalt vonErlernen des Clustermoduls in Node. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!