标签:
关键字:NodeJS, 内存泄漏,node-inspector,Chrome
OS:Windows 10
本文介绍如何使用node-inspector+Chrome查找nodejs内存泄漏。
1.创建一个Express app, 参考http://www.cnblogs.com/ldlchina/p/4054974.html。
修改app.js内容如下:
//app.js var app = require(‘express‘)(); var http = require(‘http‘).Server(app); var leakobjs = []; function LeakClass(){ this.x = 1; } app.get(‘/‘, function(req, res){ console.log(‘get /‘); for(var i = 0; i < 1000; i++){ leakobjs.push(new LeakClass()); } res.send(‘<h1>Hello world</h1>‘); }); http.listen(3000, function(){ console.log(‘listening on port 3000‘); });
运行cmd:”node app.js“
在Chrome里面打开页面:http://localhost:3000/。不停的刷新给页面,nodejs的内存将不停的增长。
2.安装使用node-inspector来调试后台程序。请参考http://www.cnblogs.com/ldlchina/p/3551277.html。
运行cmd: "node --debug app.js"。
运行cmd: "node-inspector"。
3.在Chrome里面打开http://127.0.0.1:8080/debug?port=5858, 如下图:
4.选择”Profiles“标签,选择”Take Heap Snapshot“,点击”Take Snapshot“。如下图
5.打开一个新的Chrome页面,运行http://localhost:3000/。
6.再次选择”Profiles“标签,选择”Take Heap Snapshot“,点击”Take Snapshot“。
选择Comparison,你将看到”LeakClass“导致了内存的增长,如下图。这样我们可以检查代码中关于LeakClass的部分,经验告诉我们要避免不限制的增长数组,否则在大访问量的情况下内存会耗光。
现在已经有许多好用且不断增强的工具用于定位Node.js应用的内存泄露。下面是其中的一些:
更多内容请参考:
Memory leak patterns in JavaScript。
使用Chrome+node-inspector查找NodeJS内存泄漏
标签:
原文地址:http://www.cnblogs.com/ldlchina/p/4762036.html