-
Notifications
You must be signed in to change notification settings - Fork 4
/
InfographicGeneratorCluster.js
51 lines (46 loc) · 2.09 KB
/
InfographicGeneratorCluster.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
process.argv.forEach(function (value, index, array) {
if( value.match(/^NODE_ENV=/) ) { process.env.NODE_ENV = value.replace(/^NODE_ENV=/, ''); }
});
process.env.NODE_ENV = process.env.NODE_ENV || "development";
var config = require('./app/config/config.js')[process.env.NODE_ENV];
var cluster = require('cluster');
var http = require('http');
var numCPUs = Math.max( 2, require('os').cpus().length );
console.info("InfographicGenerator started with " + numCPUs + " processes");
var timeouts = {};
if (cluster.isMaster) {
// Fork workers.
for (var i = 0; i < numCPUs; i++) {
cluster.fork();
}
cluster.on('online', function(worker) {
console.info("worker " + worker.uniqueID+":"+worker.process.pid + " responded after it was forked");
});
cluster.on('fork', function(worker) {
timeouts[worker.uniqueID] = setTimeout(function(){
console.info("worker " + worker.uniqueID+":"+worker.process.pid + " timed out after 2000ms");
worker.kill(); // sets worker.suicide = true
}, 3000);
});
cluster.on('listening', function(worker, address) {
console.info("worker " + worker.uniqueID+":"+worker.process.pid + " is now connected to " + address.address + ":" + address.port);
clearTimeout(timeouts[worker.uniqueID]);
});
cluster.on('disconnect', function(worker) {
console.info('worker ' + worker.uniqueID+":"+worker.process.pid + ' has disconnected');
});
cluster.on('exit', function(worker, code, signal) {
clearTimeout(timeouts[worker.uniqueID]);
});
cluster.on('exit', function(worker, code, signal) {
// if (worker.suicide === true) {
// console.info('worker ' + worker.uniqueID+":"+worker.process.pid + ' died ('+exitCode+'). suicide, not restarting');
// } else {
var exitCode = worker.process.exitCode;
console.info('worker ' + worker.uniqueID+":"+worker.process.pid + ' died ('+exitCode+'). restarting...');
cluster.fork(); // restart
// }
});
} else {
var server = require("./InfographicGenerator.js");
}