mediawiki-extensions-Visual.../api/server.js
Catrope c79b62f869 When the main server process is killed, kill the children too
Change-Id: If07a8c290d5c1d4ac977222fe8cd25ef345c4132
2012-07-14 16:08:30 -07:00

44 lines
1.3 KiB
JavaScript

/**
* A very basic cluster-based server runner. Restarts failed workers, but does
* not much else right now.
*/
var cluster = require('cluster');
var app = require('./ParserService.js');
// Start a few more workers than there are cpus visible to the OS, so that we
// get some degree of parallelism even on single-core systems. A single
// long-running request would otherwise hold up all concurrent short requests.
var numCPUs = require('os').cpus().length + 3;
if (cluster.isMaster) {
// Fork workers.
for (var i = 0; i < numCPUs; i++) {
cluster.fork();
}
cluster.on('death', function(worker) {
if(!worker.suicide) {
console.log('worker ' + worker.pid + ' died, restarting.');
// restart worker
cluster.fork();
}
});
process.on('SIGTERM', function() {
console.log('master shutting down, killing workers');
for(var i = 0; i < workers.length; i++) {
console.log('Killing worker ' + i + ' with PID ' + workers[i].pid);
// disconnect() doesn't work for some reason
//workers[i].disconnect();
workers[i].kill('SIGTERM');
}
console.log('Done killing workers, bye');
process.exit(1);
} );
} else {
process.on('SIGTERM', function() {
console.log('Worker shutting down');
process.exit(1);
});
app.listen(8000);
}