Skip to content

Commit

Permalink
Improve monitoring performances
Browse files Browse the repository at this point in the history
  • Loading branch information
soyuka committed Mar 17, 2018
1 parent a60580a commit 942c8e4
Show file tree
Hide file tree
Showing 3 changed files with 121 additions and 41 deletions.
112 changes: 72 additions & 40 deletions lib/God/ActionMethods.js
Original file line number Diff line number Diff line change
Expand Up @@ -41,55 +41,63 @@ module.exports = function(God) {
*/
God.getMonitorData = function getMonitorData(env, cb) {
var processes = God.getFormatedProcesses();
// keep a map index/pid for later
var map = {}
var pids = processes.filter(filterBadProcess)
.map(function(pro, i) {
var pid = getProcessId(pro)
map[pid] = i;
return pid;
})

if (pids.length === 0) {
cb(null, processes.map(function(pro) {
pro['monit'] = {
memory : 0,
cpu : 0
};

async.eachSeries(processes, function computeMonitor(pro, next) {
if (pro.pm2_env.status == cst.ONLINE_STATUS) {
var pid = pro.pid;

if (pro.pm2_env.axm_options && pro.pm2_env.axm_options.pid) {
if (isNaN(pro.pm2_env.axm_options.pid)) {
pro['monit'] = {
memory : 0,
cpu : 0
};
return process.nextTick(next);
}
pid = pro.pm2_env.axm_options.pid;
return pro
}))

return
}

pidusage.stat(pids, function retPidUsage(err, statistics) {
if (err) {
console.error('Error caught while calling pidusage');
console.error(err);
}

processes.forEach(function(pro) {
if (filterBadProcess(pro) === false) {
pro['monit'] = {
memory : 0,
cpu : 0
};

return;
}

pidusage.stat(pid, function retPidUsage(err, res) {
if (err) {
// Do not log, some time modules does not retrieve PID
// console.error('Error caught while calling pidusage');
// console.error(err);
pro['monit'] = {
memory : 0,
cpu : 0
};
return next();
}
var pid = getProcessId(pro);
var stat = statistics[map[pid]];

if (!stat) {
pro['monit'] = {
memory : Math.floor(res.memory),
cpu : Math.floor(res.cpu)
memory : 0,
cpu : 0
};
res = null;
pid = null;
return next();
});
}
else {
return;
}

pro['monit'] = {
memory : 0,
cpu : 0
memory: Math.floor(stat.memory),
cpu: Math.floor(stat.cpu)
};
return next();
}
}, function retMonitor(err, res) {
if (err) return cb(God.logAndGenerateError(err), null);
return cb(null, processes);
});
});

cb(null, processes);
});
};

/**
Expand Down Expand Up @@ -841,3 +849,27 @@ module.exports = function(God) {
});
};
};

function filterBadProcess(pro) {
if (pro.pm2_env.status !== cst.ONLINE_STATUS) {
return false;
}

if (pro.pm2_env.axm_options && pro.pm2_env.axm_options.pid) {
if (isNaN(pro.pm2_env.axm_options.pid)) {
return false;
}
}

return true;
}

function getProcessId(pro) {
var pid = pro.pid

if (pro.pm2_env.axm_options && pro.pm2_env.axm_options.pid) {
pid = pro.pm2_env.axm_options.pid;
}

return pid
}
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -174,7 +174,7 @@
"moment": "^2.19",
"needle": "^2.2.0",
"nssocket": "0.6.0",
"pidusage": "^2.0.0",
"pidusage": "^2.0.3",
"pm2-axon": "3.1.0",
"pm2-axon-rpc": "0.5.0",
"pm2-deploy": "^0.3.9",
Expand Down
48 changes: 48 additions & 0 deletions test/programmatic/god.mocha.js
Original file line number Diff line number Diff line change
Expand Up @@ -256,4 +256,52 @@ describe('God', function() {
});
});

it('should get monitor data', function(done) {
var f = require('child_process').fork('../fixtures/echo.js')

var processes = [
// stopped status
{
pm2_env: {status: cst.STOPPED_STATUS}
},
// axm pid
{
pm2_env: {
status: cst.ONLINE_STATUS, axm_options: {pid: process.pid}
}
},
// axm pid is NaN
{
pm2_env: {
status: cst.ONLINE_STATUS, axm_options: {pid: 'notanumber'}
}
},
{
pm2_env: {
status: cst.ONLINE_STATUS
},
pid: f.pid
}
]

// mock
var g = {
getFormatedProcesses: function() {
return processes
}
}

require('../../lib/God/ActionMethods.js')(g)

g.getMonitorData({}, function(err, procs) {
should(err).be.null();
procs.length.should.be.equal(processes.length);
procs[0].monit.should.be.deepEqual({memory: 0, cpu: 0});
procs[1].monit.memory.should.be.greaterThan(0);
procs[2].monit.should.be.deepEqual({memory: 0, cpu: 0});
procs[3].monit.memory.should.be.greaterThan(0);
f.kill()
done()
})
});
});

0 comments on commit 942c8e4

Please sign in to comment.