【发布时间】:2015-11-23 03:20:03
【问题描述】:
我有一个基于 restify 的应用程序。我没有内存泄漏,但是在清除 gc 期间我的内存增长很大,然后是重量级的 mark-sweep gc 并清理了内存。
它会影响我的应用程序的性能。
[2268] 266859 ms: Scavenge 61.5 (119.5) -> 46.0 (119.5) MB, 2.2 ms [allocation failure].
[2268] 267084 ms: Scavenge 63.7 (119.5) -> 48.3 (119.5) MB, 6.2 ms [allocation failure].
[2268] 267289 ms: Scavenge 66.0 (119.5) -> 50.6 (119.5) MB, 2.6 ms [allocation failure].
[2268] 267504 ms: Scavenge 68.3 (119.5) -> 52.8 (119.5) MB, 2.4 ms [allocation failure].
[2268] 267700 ms: Scavenge 70.5 (119.5) -> 55.1 (119.5) MB, 2.7 ms [allocation failure].
....
[2268] 275913 ms: Scavenge 154.2 (183.5) -> 138.8 (183.5) MB, 2.4 ms [allocation failure].
[2268] 276161 ms: Scavenge 157.5 (185.5) -> 142.1 (185.5) MB, 2.7 ms (+ 2.4 ms in 18 steps since last GC) [allocation failure].
[2268] 276427 ms: Scavenge 159.8 (187.5) -> 144.3 (187.5) MB, 2.5 ms (+ 36.3 ms in 236 steps since last GC) [allocation failure].
[2268] 276494 ms: Mark-sweep 147.7 (188.5) -> 43.7 (121.5) MB, 20.1 ms (+ 45.1 ms in 298 steps since start of marking, biggest step 0.5 ms) [GC interrupt] [GC in old space requested].
当我尝试访问不存在的 url 时会发生这种行为
ab -c 100 -n 10000000 -k http://localhost:1337/invalid/url
我不能真正使用节点检查器来跟踪导致如此剧烈的内存增长的原因,因为它会在获取堆快照之前请求完整的 gc。
我有哪些选择可以跟踪导致如此快速的内存增长的原因?
如何找出哪些对象在清除过程中幸存下来,但在标记-扫描 gc 中没有幸存下来?
谢谢,
更新 1 所以没有办法看到中年清理的内容。这是提示,如果您在清除期间看到内存快速增加,但随后随着标记和扫描突然下降,则意味着您的代码在大空间中创建数据。例如,长堆栈跟踪。 Restify 生成巨大的堆栈跟踪,应该在生产中禁用。
【问题讨论】:
标签: node.js memory garbage-collection restify node-inspector