2

我使用 node-memwatch 来监控节点应用程序的内存使用情况。简化代码如下

@file test.js
var memwatch = require('memwatch');
var util = require('util');

var leak = [];

setInterval(function() {
  leak.push(new Error("leak string"));
}, 1);

memwatch.on('stats', function(stats) {
    console.log('MEM watch: ' + JSON.stringify(stats));
    console.log('Process: ' + util.inspect(process.memoryUsage()));

});

运行'node test.js',我得到下面的输出。

MEM watch: {"num_full_gc":1,"num_inc_gc":6,"heap_compactions":1,"usage_trend":0,"estimated_base":8979176,"current_base":8979176,"min":0,"max":0}
Process: { rss: 28004352, heapTotal: 19646208, heapUsed: 9303856 }

有谁知道estimated_base 和current_base 是什么意思?在页面https://github.com/lloyd/node-memwatch中,它们没有详细描述。

问候,

杰弗里

4

1 回答 1

1

Memwatch 将其结果分为两个时段。RECENT_PERIOD 需要 10 次连续 GC,ANCIENT_PERIOD 需要 120 次连续 GC。

  • estimate_base = 执行 10 次连续 GC 后的堆大小。这是 RECENT_PERIOD。
  • current_base = GC 之后的堆大小。
  • base min = 为给定时间段记录的堆大小的最小值。
  • base max = 给定时间段内记录的堆大小的最大值。

如果您点击此链接,您将能够查看代码:Memwatch

于 2014-01-11T22:52:59.027 回答