如何在node.js中获取子进程内存使用?

时间:2012-05-24 02:39:46

标签: node.js memory-management child-process

我知道有一个api process.memoryUsage()来获取当前进程的内存使用情况。

但是如果我通过child_process.spawn(command,[args],[options])启动一个新的子进程,并且我得到一个ChildProcess对象,那么如何获得新的进程内存使用?

3 个答案:

答案 0 :(得分:3)

我们可以使用nodejs ipc协议获得多平台解决方案。您只需要设置事件以从父进程请求内存使用,然后从生成的子进程发送process.memoryUsage()

parent.js

var ChildProcess = require('child_process'),
    child = ChildProcess.fork('./child.js');

child.on('message', function(payload){
    console.log(payload.memUsage);
});

child.send('get_mem_usage');

并且在child.js中可能看起来像这样

process.on('message', function(msg){
    if(msg === 'get_mem_usage'){
         process.send({memUsage: process.memoryUsage()});
    }
});

答案 1 :(得分:2)

获取孩子记忆的最简单方法是安装pidusage

链接:https://www.npmjs.com/package/pidusage

在控制台中编写以下代码进行安装:

在Windows命令中:npm i pidusage --save
在Mac命令中:sudo npm i pidusage --save

let pidusage = require('pidusage');

const cp = require("child_process");

const child = cp.spawn('ls', ['-lh', '/usr']);

pidusage(child.pid, function (err, stats) {

console.log(stats);

});
/*
Output: 
{
   cpu: 10.0,            // percentage (from 0 to 100*vcore)
   memory: 357306368,    // bytes
   ppid: 312,            // PPID
   pid: 727,             // PID
   ctime: 867000,        // ms user + system time
   elapsed: 6650000,     // ms since the start of the process
   timestamp: 864000000  // ms since epoch
}
*/

如果要获得多个孩子的内存,则需要更改child.pid和数组[child.pid,child2.pid],函数(错误,统计信息)...

答案 2 :(得分:0)

如果你在unix环境中,那么你可以使用ps(使用/proc/<pid>/stat底层)。这是一个例子:

// Spawn a node process
var child_process = require('child_process');
var child = child_process.spawn('node');

// Now get its pid.
child_process.exec('ps -p' + child.pid + ' -o vsize=',  function (err, stdout, stderr) {
  err = err || stderr;
  if (err) {
      return console.log('BAD Luck buddy: ', err);
  }
  console.log('YOU\'ve done it', parseInt(stdout, 10));
});

这是用ubuntu 12.04和OS X lion测试的。虽然不认为它会在Windows中运行。