2016-05-26 09:58:50 +02:00
|
|
|
/**
|
|
|
|
* Mailvelope - secure email with OpenPGP encryption for Webmail
|
|
|
|
* Copyright (C) 2016 Mailvelope GmbH
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License version 3
|
|
|
|
* as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
const cluster = require('cluster');
|
|
|
|
const numCPUs = require('os').cpus().length;
|
2016-05-27 19:57:48 +02:00
|
|
|
const config = require('config');
|
2017-08-18 18:01:34 +08:00
|
|
|
const log = require('winston');
|
2017-08-18 18:04:43 +08:00
|
|
|
const papertrail = require('./src/dao/papertrail');
|
2016-05-26 09:58:50 +02:00
|
|
|
|
2017-08-17 19:16:49 +08:00
|
|
|
log.level = config.log.level;
|
2017-08-18 18:04:43 +08:00
|
|
|
papertrail.init(config.papertrail);
|
2016-05-27 19:57:48 +02:00
|
|
|
|
2016-05-26 13:58:38 +02:00
|
|
|
//
|
|
|
|
// Start worker cluster depending on number of CPUs
|
|
|
|
//
|
|
|
|
|
|
|
|
if (cluster.isMaster) {
|
2016-06-01 08:59:25 +02:00
|
|
|
for (let i = 0; i < numCPUs; i++) {
|
2016-05-26 13:58:38 +02:00
|
|
|
cluster.fork();
|
|
|
|
}
|
2017-08-17 19:16:49 +08:00
|
|
|
cluster.on('fork', worker => log.info('cluster', `Forked worker #${worker.id} [pid:${worker.process.pid}]`));
|
2016-05-26 13:58:38 +02:00
|
|
|
cluster.on('exit', worker => {
|
2017-08-17 19:16:49 +08:00
|
|
|
log.warn('cluster', `Worker #${worker.id} [pid:${worker.process.pid}] died`);
|
2016-05-26 13:58:38 +02:00
|
|
|
setTimeout(() => cluster.fork(), 5000);
|
|
|
|
});
|
|
|
|
} else {
|
2017-08-17 19:16:49 +08:00
|
|
|
require('./src');
|
2016-05-26 13:58:38 +02:00
|
|
|
}
|
|
|
|
|
2016-05-26 09:58:50 +02:00
|
|
|
//
|
|
|
|
// Error handling
|
|
|
|
//
|
|
|
|
|
|
|
|
process.on('SIGTERM', () => {
|
|
|
|
log.warn('exit', 'Exited on SIGTERM');
|
|
|
|
process.exit(0);
|
|
|
|
});
|
|
|
|
|
|
|
|
process.on('SIGINT', () => {
|
|
|
|
log.warn('exit', 'Exited on SIGINT');
|
|
|
|
process.exit(0);
|
|
|
|
});
|
|
|
|
|
|
|
|
process.on('uncaughtException', err => {
|
2016-05-28 15:37:29 +02:00
|
|
|
log.error('index', 'Uncaught exception', err);
|
2016-05-26 09:58:50 +02:00
|
|
|
process.exit(1);
|
2017-08-15 16:03:06 +08:00
|
|
|
});
|