node/test/fixtures/clustered-server/app.js

36 lines
849 B
JavaScript

var http = require('http');
var cluster = require('cluster');
var common = require('../../common');
function handleRequest(request, response) {
response.end('hello world\n');
}
var NUMBER_OF_WORKERS = 2;
var workersOnline = 0;
if (cluster.isMaster) {
cluster.on('online', function() {
if (++workersOnline === NUMBER_OF_WORKERS) {
console.error('all workers are running');
}
});
process.on('message', function(msg) {
if (msg.type === 'getpids') {
var pids = [];
pids.push(process.pid);
for (var key in cluster.workers)
pids.push(cluster.workers[key].process.pid);
process.send({ type: 'pids', pids: pids });
}
});
for (var i = 0; i < NUMBER_OF_WORKERS; i++) {
cluster.fork();
}
} else {
var server = http.createServer(handleRequest);
server.listen(common.PORT+1000);
}