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

热点内容
黑莓50系统微信下载 浏览:276
文件名带个括号1是怎么回事 浏览:949
windows7在桌面怎么新建文件夹 浏览:318
热血街机下载的游戏在哪个文件夹 浏览:685
开心消消乐669关老版本 浏览:622
为什么程序员用英语不用汉字编程 浏览:486
ipadmini忘记密码如何解锁 浏览:712
程序员年会 浏览:31
extjsdateparsedate 浏览:517
路由器卫士账号密码 浏览:523
网易邮箱和游戏密码 浏览:634
自动复制文件到u盘 浏览:452
看事业单位工资在哪个app 浏览:191
javase764位win 浏览:859
腾讯旗下app是哪个 浏览:599
java取文本中间内容 浏览:711
请简述什么是可编程序控制器 浏览:72
谷歌网站如何生成密匙 浏览:948
宁波付学费用什么app 浏览:400
笔记本文件如何转盘 浏览:916

友情链接