2016-05-21 15:54:30 +02:00
|
|
|
'use strict';
|
|
|
|
const common = require('../common');
|
|
|
|
const http = require('http');
|
|
|
|
const cluster = require('cluster');
|
2017-04-21 18:05:28 +03:00
|
|
|
const assert = require('assert');
|
2016-05-21 15:54:30 +02:00
|
|
|
|
|
|
|
cluster.schedulingPolicy = cluster.SCHED_RR;
|
|
|
|
|
|
|
|
const server = http.createServer();
|
|
|
|
|
2020-12-10 16:53:44 -05:00
|
|
|
if (cluster.isPrimary) {
|
2017-07-10 20:55:21 -04:00
|
|
|
server.listen({ port: 0 }, common.mustCall(() => {
|
|
|
|
const worker = cluster.fork({ PORT: server.address().port });
|
2017-04-21 18:05:28 +03:00
|
|
|
worker.on('exit', common.mustCall(() => {
|
|
|
|
server.close();
|
|
|
|
}));
|
2016-05-21 15:54:30 +02:00
|
|
|
}));
|
|
|
|
} else {
|
2017-04-21 18:05:28 +03:00
|
|
|
assert(process.env.PORT);
|
2022-10-20 08:13:32 -05:00
|
|
|
process.on('uncaughtException', common.mustCall());
|
2017-04-21 18:05:28 +03:00
|
|
|
server.listen(process.env.PORT);
|
2016-05-21 15:54:30 +02:00
|
|
|
server.on('error', common.mustCall((e) => {
|
|
|
|
cluster.worker.disconnect();
|
|
|
|
throw e;
|
|
|
|
}));
|
|
|
|
}
|