导航:首页 > 编程语言 > 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代码相关的资料

热点内容
如何匹配两个excel表格相同的数据 浏览:120
苹果笔记本文件怎么找回 浏览:426
数据库怎么用游标 浏览:722
不同频率的数据如何共享 浏览:83
什么时候说解读文件 浏览:165
扬州前端程序员私活网站有哪些 浏览:657
怎么改手机网络好一点 浏览:702
浅谈微信卡券功能开发 浏览:511
线切割如何用电脑编程 浏览:227
vba如何获取已经打开的excel文件 浏览:209
什么是投标文件名 浏览:390
电脑网络断开了怎么办 浏览:492
数控车床直角怎么清角怎么编程 浏览:414
如何从流量竞争到数据智能化 浏览:176
不想升级优酷 浏览:305
tplink初始密码6位 浏览:720
如何找到绝对值最大的数据 浏览:269
vep文件怎么播放 浏览:812
ios短信同步到安卓 浏览:217
钉钉小学文件夹在哪里找 浏览:366

友情链接