如何监控Node.js的内存使用情况?
发布于 2013-11-16 20:55:27
node-memwatch:检测并查找Node.JS代码中的内存泄漏。查看此教程Tracking Down Memory Leaks in Node.js
发布于 2015-05-07 05:06:52
内置的process模块有一个memoryUsage
方法,它可以洞察当前Node.js进程的内存使用情况。以下是64位系统上Node v0.12.2中的示例:
$ node --expose-gc
> process.memoryUsage(); // Initial usage
{ rss: 19853312, heapTotal: 9751808, heapUsed: 4535648 }
> gc(); // Force a GC for the baseline.
undefined
> process.memoryUsage(); // Baseline memory usage.
{ rss: 22269952, heapTotal: 11803648, heapUsed: 4530208 }
> var a = new Array(1e7); // Allocate memory for 10m items in an array
undefined
> process.memoryUsage(); // Memory after allocating so many items
{ rss: 102535168, heapTotal: 91823104, heapUsed: 85246576 }
> a = null; // Allow the array to be garbage-collected
null
> gc(); // Force GC (requires node --expose-gc)
undefined
> process.memoryUsage(); // Memory usage after GC
{ rss: 23293952, heapTotal: 11803648, heapUsed: 4528072 }
> process.memoryUsage(); // Memory usage after idling
{ rss: 23293952, heapTotal: 11803648, heapUsed: 4753376 }
在这个简单的示例中,您可以看到分配10M个元素的数组消耗了大约80MB (看看heapUsed
)。
如果查看V8的源代码(Array::New
、Heap::AllocateRawFixedArray
、FixedArray::SizeFor
),就会发现数组使用的内存是一个固定值加上长度乘以指针的大小。后者在64位系统上是8字节,这证实了观察到的8x10= 80MB的内存差异是有意义的。
发布于 2015-10-15 17:56:46
https://stackoverflow.com/questions/20018588
复制相似问题