-
Notifications
You must be signed in to change notification settings - Fork 26
Expand file tree
/
Copy pathindex.js
More file actions
94 lines (73 loc) · 2.44 KB
/
index.js
File metadata and controls
94 lines (73 loc) · 2.44 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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
'use strict';
const config = require('./config');
const logger = require('./components/logger').getLogger('server');
const path = require('path');
const { Worker, MessageChannel } = require('worker_threads');
let web = null;
const workers = new Map();
function startWorker(id) {
const name = `worker-${id}`;
const worker = new Worker(path.join(__dirname, 'workers', 'media.js'), {
workerData: { name: name },
});
const { port1, port2 } = new MessageChannel();
worker.postMessage({ action: 'updateWebChannel', port: port2 }, [port2]);
web.postMessage({ action: 'updateWorkerChannel', id: id, port: port1 }, [port1]);
worker.on('exit', (code) => {
if (code !== 0) {
logger.warn(`Worker #${id} crashed with code ${code}. Restarting in 1s...`);
workers.delete(id);
setTimeout(() => {
startWorker(id);
}, 1000);
} else {
logger.info(`Worker #${id} stopped gracefully.`);
}
});
worker.on('error', (err) => {
logger.error(`Worker #${id} error:`, err);
});
workers.set(id, worker);
logger.info(`Worker #${id} started.`);
}
function start() {
logger.info('Starting media server...');
web = new Worker(path.join(__dirname, 'workers', 'web.js'));
web.on('exit', (code) => {
if (code !== 0) {
logger.error('Web worker crashed. Shutting down media server.');
process.exit(1);
}
});
for (let i = 0; i < config.workers.count; i++) {
startWorker(i);
}
}
function shutdown() {
logger.info('Stopping media server...');
const exitPromises = [];
if (web) {
exitPromises.push(new Promise((resolve) => {
web.once('exit', resolve);
web.postMessage({ action: 'shutdown' });
}));
}
for (const worker of workers.values()) {
exitPromises.push(new Promise((resolve) => {
worker.once('exit', resolve);
worker.postMessage({ action: 'shutdown' });
}));
};
const forceTimeout = setTimeout(() => {
logger.error('Shutdown timed out. Forcing exit.');
process.exit(1);
}, config.server.shutdownTimeout || 10000);
Promise.all(exitPromises).then(() => {
clearTimeout(forceTimeout);
logger.info('Server successfully stopped.');
process.exit(0);
});
}
process.on('SIGTERM', shutdown);
process.on('SIGINT', shutdown);
start();