fix sockets + clusters

This commit is contained in:
Matias Alejo Garcia 2015-04-15 19:38:51 -03:00
parent 03eaf58fc7
commit 4ccd3541d4
2 changed files with 31 additions and 32 deletions

47
bws.js
View File

@ -13,8 +13,9 @@ 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) {
@ -22,31 +23,29 @@ if (config.https) {
serverOpts.cert = fs.readFileSync(config.certificateFile || './ssl/certificate.pem');
}
var startOne = function() {
var start = function() {
var app = ExpressApp.start(config);
var server = config.https ? sticky(serverModule.createServer(serverOpts, app)) :
serverModule.Server(app);
var ws = WsApp.start(server, config);
server.listen(port);
console.log('Bitcore Wallet Service running on port ' + port);
};
var server;
if (!config.cluster) {
startOne();
} else {
if (!config.storageOpts.multiLevel || !config.lockOpts.lockerServer)
throw 'When running in cluster mode, multilevel and locker server need to be configured';
var clusterInstances = config.clusterInstances || numCpus;
if (cluster.isMaster) {
for (var i = 0; i < clusterInstances; i++) {
cluster.fork();
}
cluster.on('exit', function(worker, code, signal) {
console.log('worker ' + worker.process.pid + ' died');
if (config.cluster) {
server = sticky(clusterInstances, function() {
var server = config.https ? serverModule.createServer(serverOpts, app) :
serverModule.Server(app);
WsApp.start(server, config);
return server;
});
} else {
startOne();
server = config.https ? serverModule.createServer(serverOpts, app) :
serverModule.Server(app);
WsApp.start(server, config);
}
}
server.listen(port, function(err) {
if (err) console.log('ERROR: ', err);
console.log('Bitcore Wallet Service running on port ' + port);
});
};
if (config.cluster && (!config.storageOpts.multiLevel || !config.lockOpts.lockerServer))
throw 'When running in cluster mode, multilevel and locker server need to be configured';
start();

View File

@ -14,17 +14,17 @@ var config = {
storageOpts: {
dbPath: './db',
// Uncomment to use multilevel server
// multiLevel: {
// host: 'localhost',
// port: 3230,
// },
// multiLevel: {
// host: 'localhost',
// port: 3230,
// },
},
lockOpts: {
// To use locker-server, uncomment this:
// lockerServer: {
// host: 'localhost',
// port: 3231,
// },
// lockerServer: {
// host: 'localhost',
// port: 3231,
// },
},
blockchainExplorerOpts: {
livenet: {