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.49 KB
/
launcher.js
File metadata and controls
41 lines (40 loc) · 1.49 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 {onError} = require('./helpers/functions');
(async () => {
if (cluster.isMaster) {
process.title = `hyp-${process.env.CHAIN}-master`;
require('./master').main().catch(onError);
} else {
process.title = `hyp-${process.env.CHAIN}-${process.env['worker_role']}:${process.env.worker_id}`;
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': {
require('./workers/state-reader.worker').run().catch(onError);
break;
}
case 'deserializer': {
require('./workers/deserializer.worker').run().catch(onError);
break;
}
case 'continuous_reader': {
require('./workers/state-reader.worker').run().catch(onError);
break;
}
case 'ingestor': {
require('./workers/indexer.worker').run().catch(onError);
break;
}
case 'router': {
require('./workers/ws-router.worker').run().catch(onError);
break;
}
}
}, delay);
}
})();