forked from eosrio/hyperion-history-api
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathlauncher.js
More file actions
41 lines (40 loc) · 1.29 KB
/
launcher.js
File metadata and controls
41 lines (40 loc) · 1.29 KB
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
const cluster = require('cluster');
const master = require('./master');
const Workers = require('./workers/index');
const {onError} = require('./helpers/functions');
(async () => {
if (cluster.isMaster) {
master.main().catch(onError);
} else {
let delay = 0;
// Make sure readers are launched later
// TODO: use IPC to trigger
if (process.env['worker_role'] === 'reader') {
delay = process.env.DESERIALIZERS * 200;
}
setTimeout(() => {
switch (process.env['worker_role']) {
case 'reader': {
Workers.stateReader.run().catch(onError);
break;
}
case 'deserializer': {
Workers.deserializer.run().catch(onError);
break;
}
case 'continuous_reader': {
Workers.stateReader.run().catch(onError);
break;
}
case 'ingestor': {
Workers.indexer.run().catch(onError);
break;
}
case 'router': {
Workers.wsRouter.run().catch(onError);
break;
}
}
}, delay);
}
})();