From 49a7fdfe37e5be7730095cb74f6a6202bd85603c Mon Sep 17 00:00:00 2001 From: Nandan Sridhar Date: Wed, 14 Mar 2018 22:23:14 -0700 Subject: [PATCH 1/3] stop forever --- cli/cmd.js | 27 ++++++++++++++++++++++----- cli/lib/gateway.js | 6 ++++-- 2 files changed, 26 insertions(+), 7 deletions(-) diff --git a/cli/cmd.js b/cli/cmd.js index 600ccd0e1..d04127443 100644 --- a/cli/cmd.js +++ b/cli/cmd.js @@ -14,10 +14,12 @@ const rotatekey = require('./lib/rotate-key')(); const verify = require('./lib/verify')(); const run = require('./lib/gateway')(); const keyGenerator = require('./lib/key-gen')(); +const configLocations = require('../config/locations'); const prompt = require('cli-prompt'); const init = require('./lib/init'); var foreverOptions = require('../forever.json'); const forever = require('forever-monitor'); +const pidpath = configLocations.getPIDFilePath(); var portastic = require('portastic'); const setup = function setup() { @@ -249,8 +251,7 @@ const setup = function setup() { } }); } - } - else run.reload(options); + } else run.reload(options); }); commander @@ -270,10 +271,18 @@ const setup = function setup() { commander .command('forever') .option('-f, --file ', 'forever-monitor options file') + .option('-a,--action ', 'action can be start or stop; default is start') .description('Start microgateway using forever-monitor') .action((options) => { + options.action = options.action || "start"; + options.error = optionError; if (options.file) { - foreverOptions = JSON.parse(fs.readFileSync(options.file, {encoding: 'utf8'})); + foreverOptions = JSON.parse(fs.readFileSync(options.file, { + encoding: 'utf8' + })); + } + if (options.action !== "start" && options.action !== "stop") { + return options.error('action must be start or stop'); } foreverOptions ? foreverOptions : { max: 3, @@ -282,7 +291,15 @@ const setup = function setup() { minUptime: 2000 }; var child = new(forever.Monitor)(path.join(__dirname, '..', 'app.js'), foreverOptions); - child.start(); + if (options.action == "start") { + child.start(); + fs.appendFileSync(pidpath, process.pid+'|'); + } else { + var pids = fs.readFileSync(pidpath,'utf8').split('|'); + process.kill(pids[1], 'SIGINT'); + fs.unlinkSync(pidpath); + process.kill(pids[0], 'SIGINT'); + } }); commander @@ -435,4 +452,4 @@ function promptForPassword(options, cb) { } -module.exports = setup; +module.exports = setup; \ No newline at end of file diff --git a/cli/lib/gateway.js b/cli/lib/gateway.js index 94f93c380..1a83c1dd5 100644 --- a/cli/lib/gateway.js +++ b/cli/lib/gateway.js @@ -11,7 +11,7 @@ const configLocations = require('../../config/locations'); const isWin = /^win/.test(process.platform); const ipcPath = configLocations.getIPCFilePath(); const defaultPollInterval = 600; -const uuid = require('uuid'); +const uuid = require('uuid/v1'); const debug = require('debug')('microgateway'); const jsdiff = require('diff'); @@ -32,6 +32,7 @@ Gateway.prototype.start = (options) => { } catch (e) { // Socket does not exist // so ignore and proceed + debug(e); } const source = configLocations.getSourcePath(options.org, options.env, options.configDir); @@ -117,6 +118,7 @@ Gateway.prototype.start = (options) => { mgCluster.run(); console.log('PROCESS PID : ' + process.pid); + fs.appendFileSync(configLocations.getPIDFilePath(), process.pid); process.on('exit', () => { if (!isWin) { @@ -133,7 +135,7 @@ Gateway.prototype.start = (options) => { process.exit(0); }); - process.on('uncaughtException', () => { + process.on('uncaughtException',(err) => { console.error(err); debug('Caught Unhandled Exception:'); debug(err); From 5c4aadaa9b4e4681d8d9f5709ea72895ca8d5466 Mon Sep 17 00:00:00 2001 From: Nandan Sridhar Date: Wed, 14 Mar 2018 22:34:48 -0700 Subject: [PATCH 2/3] upgrade uuid --- cli/lib/gateway.js | 2 +- package.json | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/cli/lib/gateway.js b/cli/lib/gateway.js index 1a83c1dd5..42de6257c 100644 --- a/cli/lib/gateway.js +++ b/cli/lib/gateway.js @@ -75,7 +75,7 @@ Gateway.prototype.start = (options) => { edgeconfig.save(config, cache); } - config.uid = uuid.v1(); + config.uid = uuid(); var logger = gateway.Logging.init(config); var opt = {}; delete args.keys; diff --git a/package.json b/package.json index 1b745c337..169cf1389 100644 --- a/package.json +++ b/package.json @@ -33,7 +33,7 @@ "request": "^2.67.0", "rimraf": "^2.4.3", "tmp": "0.0.28", - "uuid": "^2.0.1", + "uuid": "^3.2.1", "volos-cache-memory": "^0.10.1", "volos-spikearrest-common": "^0.10.3", "volos-spikearrest-memory": "^0.10.1", From 12ad4b0707bcc9139b5764feb526c1972638265e Mon Sep 17 00:00:00 2001 From: Nandan Sridhar Date: Thu, 15 Mar 2018 09:27:14 -0700 Subject: [PATCH 3/3] unlink pid --- cli/cmd.js | 27 +++++++++++++++++++++------ cli/lib/gateway.js | 4 +++- 2 files changed, 24 insertions(+), 7 deletions(-) diff --git a/cli/cmd.js b/cli/cmd.js index d04127443..5e96f8c7e 100644 --- a/cli/cmd.js +++ b/cli/cmd.js @@ -292,13 +292,28 @@ const setup = function setup() { }; var child = new(forever.Monitor)(path.join(__dirname, '..', 'app.js'), foreverOptions); if (options.action == "start") { - child.start(); - fs.appendFileSync(pidpath, process.pid+'|'); + try { + fs.appendFileSync(pidpath, process.pid+'|'); + child.start(); + } catch (piderr) { + console.error('failed to start microgateway: ' + piderr); + process.exit(1); + } } else { - var pids = fs.readFileSync(pidpath,'utf8').split('|'); - process.kill(pids[1], 'SIGINT'); - fs.unlinkSync(pidpath); - process.kill(pids[0], 'SIGINT'); + try { + var pids = fs.readFileSync(pidpath,'utf8').split('|'); + if (pids) { + pids.forEach(function(pid){ + process.kill(parseInt(pid), 'SIGINT'); + }); + fs.unlinkSync(pidpath); + } else { + console.log('pid file not found. please run this command from the folder where microgateway was started.') + } + } catch (piderr) { + console.error('failed to stop microgateway: ' + piderr); + process.exit(1); + } } }); diff --git a/cli/lib/gateway.js b/cli/lib/gateway.js index 42de6257c..0b0f77f64 100644 --- a/cli/lib/gateway.js +++ b/cli/lib/gateway.js @@ -10,6 +10,7 @@ const JsonSocket = require('./json-socket'); const configLocations = require('../../config/locations'); const isWin = /^win/.test(process.platform); const ipcPath = configLocations.getIPCFilePath(); +const pidPath = configLocations.getPIDFilePath(); const defaultPollInterval = 600; const uuid = require('uuid/v1'); const debug = require('debug')('microgateway'); @@ -118,12 +119,13 @@ Gateway.prototype.start = (options) => { mgCluster.run(); console.log('PROCESS PID : ' + process.pid); - fs.appendFileSync(configLocations.getPIDFilePath(), process.pid); + fs.appendFileSync(pidPath, process.pid); process.on('exit', () => { if (!isWin) { console.log('Removing the socket file as part of cleanup'); fs.unlinkSync(ipcPath); + fs.unlinkSync(pidPath) } });