Adds --cluster support (#2596)
* Adds --cluster support * Restart failing child processes
This commit is contained in:
@@ -221,5 +221,9 @@ export default {
|
|||||||
env: "PARSE_SERVER_SCHEMA_CACHE_TTL",
|
env: "PARSE_SERVER_SCHEMA_CACHE_TTL",
|
||||||
help: "The TTL for caching the schema for optimizing read/write operations. You should put a long TTL when your DB is in production. default to 0; disabled.",
|
help: "The TTL for caching the schema for optimizing read/write operations. You should put a long TTL when your DB is in production. default to 0; disabled.",
|
||||||
action: numberParser("schemaCacheTTL"),
|
action: numberParser("schemaCacheTTL"),
|
||||||
|
},
|
||||||
|
"cluster": {
|
||||||
|
help: "Run with cluster, optionally set the number of processes default to os.cpus().length",
|
||||||
|
action: numberParser("cluster"),
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -4,6 +4,8 @@ import { ParseServer } from '../index';
|
|||||||
import definitions from './cli-definitions';
|
import definitions from './cli-definitions';
|
||||||
import program from './utils/commander';
|
import program from './utils/commander';
|
||||||
import { mergeWithOptions } from './utils/commander';
|
import { mergeWithOptions } from './utils/commander';
|
||||||
|
import cluster from 'cluster';
|
||||||
|
import os from 'os';
|
||||||
|
|
||||||
program.loadDefinitions(definitions);
|
program.loadDefinitions(definitions);
|
||||||
|
|
||||||
@@ -48,12 +50,7 @@ if (!options.appId || !options.masterKey || !options.serverURL) {
|
|||||||
process.exit(1);
|
process.exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
const app = express();
|
function logStartupOptions(options) {
|
||||||
const api = new ParseServer(options);
|
|
||||||
app.use(options.mountPath, api);
|
|
||||||
|
|
||||||
var server = app.listen(options.port, function() {
|
|
||||||
|
|
||||||
for (let key in options) {
|
for (let key in options) {
|
||||||
let value = options[key];
|
let value = options[key];
|
||||||
if (key == "masterKey") {
|
if (key == "masterKey") {
|
||||||
@@ -61,15 +58,46 @@ var server = app.listen(options.port, function() {
|
|||||||
}
|
}
|
||||||
console.log(`${key}: ${value}`);
|
console.log(`${key}: ${value}`);
|
||||||
}
|
}
|
||||||
console.log('');
|
}
|
||||||
console.log('parse-server running on '+options.serverURL);
|
|
||||||
});
|
|
||||||
|
|
||||||
var handleShutdown = function() {
|
function startServer(options, callback) {
|
||||||
console.log('Termination signal received. Shutting down.');
|
const app = express();
|
||||||
server.close(function () {
|
const api = new ParseServer(options);
|
||||||
process.exit(0);
|
app.use(options.mountPath, api);
|
||||||
|
|
||||||
|
var server = app.listen(options.port, callback);
|
||||||
|
|
||||||
|
var handleShutdown = function() {
|
||||||
|
console.log('Termination signal received. Shutting down.');
|
||||||
|
server.close(function () {
|
||||||
|
process.exit(0);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
process.on('SIGTERM', handleShutdown);
|
||||||
|
process.on('SIGINT', handleShutdown);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (options.cluster) {
|
||||||
|
const numCPUs = typeof options.cluster === 'number' ? options.cluster : os.cpus().length;
|
||||||
|
if (cluster.isMaster) {
|
||||||
|
logStartupOptions(options);
|
||||||
|
for(var i = 0; i < numCPUs; i++) {
|
||||||
|
cluster.fork();
|
||||||
|
}
|
||||||
|
cluster.on('exit', (worker, code, signal) => {
|
||||||
|
console.log(`worker ${worker.process.pid} died... Restarting`);
|
||||||
|
cluster.fork();
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
startServer(options, () => {
|
||||||
|
console.log('['+process.pid+'] parse-server running on '+options.serverURL);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
startServer(options, () => {
|
||||||
|
logStartupOptions(options);
|
||||||
|
console.log('');
|
||||||
|
console.log('['+process.pid+'] parse-server running on '+options.serverURL);
|
||||||
});
|
});
|
||||||
};
|
}
|
||||||
process.on('SIGTERM', handleShutdown);
|
|
||||||
process.on('SIGINT', handleShutdown);
|
|
||||||
|
|||||||
Reference in New Issue
Block a user