导航:首页 > 编程语言 > curlfc代码

curlfc代码

发布时间:2025-01-06 15:16:19

⑴ 怎么自己检查NodeJS的代码是否存在内存泄漏

首先,我们来看一个简单的内存泄漏
var http = require('http');

var server = http.createServer(function (req, res) {
for (var i=0; i<1000; i++) {
server.on('request', function leakyfunc() {});
}

res.end('Hello World\n');
}).listen(1337, '127.0.0.1');
server.setMaxListeners(0);
console.log('Server running at http://127.0.0.1:1337/. Process PID: ', process.pid);

每一个请求我们增加了1000个导致泄漏的监听器。如果我们在一个shell控制台中执行以下命令:
while true; do curl "http://127.0.0.1:1337/"; done

然后在另外一个shell控制台中查看我们的进程
top -pid

我们会看到node进程产生异常高的内存占用,我们的node进程看起来失控了。那么,当我们的node进程出现这种情况的时候,通常我们该怎样诊断出问题的根源?
内存泄露的检测
npm模块 memwatch 是一个非常好的内存泄漏检查工具,让我们先将这个模块安装到我们的app中去,执行以下命令:
npm install --save memwatch

然后,在我们的代码中,添加:
var memwatch = require('memwatch');
//memwatch.setup(); 原文有这行代码,最新版本的memwatch已去掉这个方法(译者注)

然后监听 leak 事件
memwatch.on('leak', function(info) {
console.error('Memory leak detected: ', info);
});

这样当我们执行我们的测试代码,我们会看到下面的信息:
{
start: Fri Jan 02 2015 10:38:49 GMT+0000 (GMT),
end: Fri Jan 02 2015 10:38:50 GMT+0000 (GMT),
growth: 7620560,
reason: 'heap growth over 5 consecutive GCs (1s) - -2147483648 bytes/hr'
}

参考文献https://w3ctech.com/topic/842#rd?sukey=0e1af5eeb690c5521ad1e164fb

阅读全文

与curlfc代码相关的资料

热点内容
文件夹代码加密 浏览:592
win10很容易死机 浏览:347
h5怎么上传投票数据 浏览:710
wps如何设密码 浏览:171
js接口安全域名作用 浏览:634
java字符为空 浏览:355
revit族文件在哪里找 浏览:825
韩剧巧克力哪个app 浏览:488
extjs5grid在线演示 浏览:53
数据库索引mysql 浏览:480
恢复桌面数据用什么软件 浏览:478
juicessh使用教程 浏览:753
苹果系统还原密码错误 浏览:211
程序员用104键的键盘推荐 浏览:528
小米手机接收的蓝牙文件去哪里找 浏览:561
点对点网络共享 浏览:245
win7一键配置java环境 浏览:711
adobe软件为文件夹加密 浏览:853
网络电视乐视 浏览:388
互联网络信息中心net 浏览:909

友情链接