-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathindex-cluster.js
59 lines (41 loc) · 1023 Bytes
/
index-cluster.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
51
52
53
54
55
56
57
58
59
/**
*
* Primary file for API
*
*/
// dependencies
var server = require('./lib/server');
var workers = require('./lib/workers');
var cli = require('./lib/cli');
var cluster = require('cluster');
var os = require('os');
// declare the app
var app = {};
// initialization method
app.init = function (callback) {
//if on master thread, start workers n cli
if (cluster.isMaster) {
//start workers
workers.init();
//start cli, but make sure it starts last
setTimeout(function () {
cli.init();
callback();
}, 50)
//fork the process
for(var i = 0; i<os.cpus().length; i++) {
cluster.fork();
}
} else {
//start servwer
//running on multiple cores
// if not on master thread, start http
server.init();
}
};
//slef envoking only if required directly
if (require.main === module) {
app.init(function () { });
}
//export app
module.exports = app;