|
|
|
#!/usr/bin/env node
|
|
|
|
|
|
|
|
var async = require('async');
|
|
|
|
var fs = require('fs');
|
|
|
|
|
|
|
|
var ExpressApp = require('./lib/expressapp');
|
|
|
|
var config = require('./config');
|
|
|
|
var log = require('npmlog');
|
|
|
|
log.debug = log.verbose;
|
|
|
|
log.disableColor();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var port = process.env.BWS_PORT || config.port || 3232;
|
|
|
|
|
|
|
|
var cluster = require('cluster');
|
|
|
|
var http = require('http');
|
|
|
|
var numCPUs = require('os').cpus().length;
|
|
|
|
var clusterInstances = config.clusterInstances || numCPUs;
|
|
|
|
var serverModule = config.https ? require('https') : require('http');
|
|
|
|
|
|
|
|
var serverOpts = {};
|
|
|
|
|
|
|
|
if (config.https) {
|
|
|
|
serverOpts.key = fs.readFileSync(config.privateKeyFile || './ssl/privatekey.pem');
|
|
|
|
serverOpts.cert = fs.readFileSync(config.certificateFile || './ssl/certificate.pem');
|
|
|
|
if (config.ciphers) {
|
|
|
|
serverOpts.ciphers = config.ciphers;
|
|
|
|
serverOpts.honorCipherOrder = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
// This sets the intermediate CA certs only if they have all been designated in the config.js
|
|
|
|
if (config.CAinter1 && config.CAinter2 && config.CAroot) {
|
|
|
|
serverOpts.ca = [fs.readFileSync(config.CAinter1),
|
|
|
|
fs.readFileSync(config.CAinter2),
|
|
|
|
fs.readFileSync(config.CAroot)
|
|
|
|
];
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
if (config.cluster && !config.lockOpts.lockerServer)
|
|
|
|
throw 'When running in cluster mode, locker server need to be configured';
|
|
|
|
|
|
|
|
if (config.cluster && !config.messageBrokerOpts.messageBrokerServer)
|
|
|
|
throw 'When running in cluster mode, message broker server need to be configured';
|
|
|
|
|
|
|
|
var expressApp = new ExpressApp();
|
|
|
|
|
|
|
|
function startInstance(cb) {
|
|
|
|
var server = config.https ? serverModule.createServer(serverOpts, expressApp.app) : serverModule.Server(expressApp.app);
|
|
|
|
|
|
|
|
server.on('connection', function(socket) {
|
|
|
|
socket.setTimeout(300 * 1000);
|
|
|
|
})
|
|
|
|
|
|
|
|
expressApp.start(config, function(err) {
|
|
|
|
if (err) {
|
|
|
|
log.error('Could not start BWS instance', err);
|
|
|
|
return cb(err);
|
|
|
|
}
|
|
|
|
|
|
|
|
server.listen(port);
|
|
|
|
return cb();
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
var logStart = function(err) {
|
|
|
|
if (err) {
|
|
|
|
log.error('Error:' + err);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cluster.worker)
|
|
|
|
log.info('BWS Instance ' + cluster.worker.id + ' running');
|
|
|
|
else
|
|
|
|
log.info('BWS running');
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
if (config.cluster) {
|
|
|
|
|
|
|
|
if (cluster.isMaster) {
|
|
|
|
|
|
|
|
// Count the machine's CPUs
|
|
|
|
var instances = config.clusterInstances || require('os').cpus().length;
|
|
|
|
|
|
|
|
log.info('Starting ' + instances + ' instances on port:' + port);
|
|
|
|
|
|
|
|
// Create a worker for each CPU
|
|
|
|
for (var i = 0; i < instances; i += 1) {
|
|
|
|
cluster.fork();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Listen for dying workers
|
|
|
|
cluster.on('exit', function(worker) {
|
|
|
|
// Replace the dead worker,
|
|
|
|
log.error('Worker ' + worker.id + ' died :(');
|
|
|
|
cluster.fork();
|
|
|
|
});
|
|
|
|
// Code to run if we're in a worker process
|
|
|
|
} else {
|
|
|
|
startInstance(logStart);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
log.info('Starting on port: ' + port);
|
|
|
|
startInstance(logStart);
|
|
|
|
};
|