wildduck/server.js

62 lines
1.8 KiB
JavaScript
Raw Normal View History

/* eslint global-require:0 */
2017-03-06 05:45:50 +08:00
'use strict';
2017-03-06 22:13:40 +08:00
let config = require('config');
let log = require('npmlog');
let packageData = require('./package.json');
2017-03-06 05:45:50 +08:00
log.level = config.log.level;
require('./logger');
let printLogo = () => {
log.info('App', '.##...##..######..##......#####...#####...##..##...####...##..##.');
log.info('App', '.##...##....##....##......##..##..##..##..##..##..##..##..##.##..');
log.info('App', '.##.#.##....##....##......##..##..##..##..##..##..##......####...');
log.info('App', '.#######....##....##......##..##..##..##..##..##..##..##..##.##..');
log.info('App', '..##.##...######..######..#####...#####....####....####...##..##.');
log.info('App', ' --- v' + packageData.version + ' ---');
};
2017-03-06 05:45:50 +08:00
if (!config.processes || config.processes <= 1) {
printLogo();
if (config.ident) {
process.title = config.ident;
2017-03-06 05:45:50 +08:00
}
// single process mode, do not fork anything
require('./worker.js');
} else {
let cluster = require('cluster');
if (cluster.isMaster) {
printLogo();
if (config.ident) {
process.title = config.ident + ' master';
}
log.info('App', `Master [${process.pid}] is running`);
let forkWorker = () => {
let worker = cluster.fork();
log.info('App', `Forked worker ${worker.process.pid}`);
};
// Fork workers.
for (let i = 0; i < config.processes; i++) {
forkWorker();
2017-03-06 22:13:40 +08:00
}
cluster.on('exit', worker => {
log.info('App', `Worker ${worker.process.pid} died`);
setTimeout(forkWorker, 1000);
2017-03-06 05:45:50 +08:00
});
} else {
if (config.ident) {
process.title = config.ident + ' worker';
}
require('./worker.js');
}
}