node.js – 使用memwatch进一步查找内存泄漏

最近我用node.js开始了我的第一个项目,我可以肯定地说我很喜欢它.所有模块都非常强大;然而,似乎我有一个“轻微”的内存泄漏导致我的服务器在大约一个小时后崩溃(命中99-100%的cpu).我一直试图解决这个问题一段时间了.

幸运的是,经过一番搜索,我发现了一个名为memwatch的流行工具.我当然安装了模块,并开始记录我服务器进程的内存使用/存储.

最后,通过查看日志后,我发现了可能的原因.

{
    "what": "String","size_bytes": 9421368,"size": "8.98 mb","+": 16635,"-": 533
  }

当然,在30秒内,这个小虫子增加了9mb(非常不寻常).知道我的内存泄漏似乎是字符串类型,这是很好的和花花公子,但我到底在哪里?有什么方法可以得到更准确的结果吗?

我查看了我的代码,但我的代码中确实没有一个字符串可能会像这样增长.是否有可能这个字符串实际上不是我的代码的一部分,更多的是节点或Socket.IO模块的一部分?

解决方法

正确的方法.使用StrongOps(以前称为Nodefly)来分析内存.隔离泄漏物体的类型.查看堆保留大小以及实例计数.越来越多的实例计数与稳定的工作量将指向少数吸烟枪.

我相信StrongOps使用memwatch一些V8探查器/ GC代码.更好的自动化见链接http://strongloop.com/node-js-performance/strongops/

然后使用node-heapdump模块,他们的联合创始人(核心贡献者Ben Noordhuis)写道将泄漏分离到集合对象,GC根和代码行.

请参阅Ben – http://strongloop.com/strongblog/how-to-heap-snapshots/博客

相关文章

这篇文章主要介绍“基于nodejs的ssh2怎么实现自动化部署”的...
本文小编为大家详细介绍“nodejs怎么实现目录不存在自动创建...
这篇“如何把nodejs数据传到前端”文章的知识点大部分人都不...
本文小编为大家详细介绍“nodejs如何实现定时删除文件”,内...
这篇文章主要讲解了“nodejs安装模块卡住不动怎么解决”,文...
今天小编给大家分享一下如何检测nodejs有没有安装成功的相关...