node/doc/api/cluster.markdown

98 lines
2.8 KiB
Markdown
Raw Normal View History

2012-02-28 03:07:49 +08:00
# Cluster
2011-10-13 05:19:32 +08:00
A single instance of Node runs in a single thread. To take advantage of
multi-core systems the user will sometimes want to launch a cluster of Node
processes to handle the load.
The cluster module allows you to easily create a network of processes that
all share server ports.
2011-10-13 05:19:32 +08:00
var cluster = require('cluster');
var http = require('http');
2011-11-05 06:11:19 +08:00
var numCPUs = require('os').cpus().length;
if (cluster.isMaster) {
2011-11-05 06:11:19 +08:00
// Fork workers.
for (var i = 0; i < numCPUs; i++) {
cluster.fork();
}
cluster.on('death', function(worker) {
console.log('worker ' + worker.pid + ' died');
});
} else {
// Worker processes have a http server.
http.Server(function(req, res) {
res.writeHead(200);
res.end("hello world\n");
}).listen(8000);
}
Running node will now share port 8000 between the workers:
% node server.js
2011-10-13 05:19:32 +08:00
Worker 2438 online
Worker 2437 online
The difference between `cluster.fork()` and `child_process.fork()` is simply
that cluster allows TCP servers to be shared between workers. `cluster.fork`
is implemented on top of `child_process.fork`. The message passing API that
is available with `child_process.fork` is available with `cluster` as well.
As an example, here is a cluster which keeps count of the number of requests
in the master process via message passing:
var cluster = require('cluster');
var http = require('http');
var numReqs = 0;
if (cluster.isMaster) {
// Fork workers.
for (var i = 0; i < 2; i++) {
var worker = cluster.fork();
worker.on('message', function(msg) {
if (msg.cmd && msg.cmd == 'notifyRequest') {
numReqs++;
}
});
}
setInterval(function() {
console.log("numReqs =", numReqs);
}, 1000);
} else {
// Worker processes have a http server.
http.Server(function(req, res) {
res.writeHead(200);
res.end("hello world\n");
// Send message to master process
process.send({ cmd: 'notifyRequest' });
}).listen(8000);
}
2012-02-28 03:07:49 +08:00
## cluster.fork()
2011-11-05 06:11:19 +08:00
Spawn a new worker process. This can only be called from the master process.
2012-02-28 03:07:49 +08:00
## cluster.isMaster
## cluster.isWorker
2011-11-05 06:11:19 +08:00
Boolean flags to determine if the current process is a master or a worker
process in a cluster. A process `isMaster` if `process.env.NODE_WORKER_ID`
is undefined.
2012-02-28 03:07:49 +08:00
## Event: 'death'
2011-11-05 06:11:19 +08:00
When any of the workers die the cluster module will emit the 'death' event.
This can be used to restart the worker by calling `fork()` again.
2011-11-05 06:11:19 +08:00
cluster.on('death', function(worker) {
console.log('worker ' + worker.pid + ' died. restart...');
cluster.fork();
});
2012-02-28 03:07:49 +08:00
2011-11-05 06:11:19 +08:00
Different techniques can be used to restart the worker depending on the
application.