专栏名称: Fundebug
Fundebug为JavaScript、微信小程序及Node.js开发团队提供专业的线上代码bug监控和智能分析服务。
目录
相关文章推荐
前端大全  ·  10年了,开发人员仍然不明白 ... ·  昨天  
前端大全  ·  前端行情变了,差别真的挺大。。。 ·  3 天前  
前端早读课  ·  【开源】TinyEngine开启新篇章,服务 ... ·  3 天前  
51好读  ›  专栏  ›  Fundebug

Node.js性能分析神器Easy-Monitor

Fundebug  · 公众号  · 前端  · 2018-03-02 09:27

正文

摘要: 使用Easy-Monitor,可以准确定位Node.js应用的性能瓶颈,帮助我们优化代码性能。

当应用出现性能问题时,最大的问题在于: 如何准确定位造成性能瓶颈的代码呢? 对于Node.js开发者,这里推荐一下Easy-Monitor,它应该是阿里巴巴某个90后程序员开发的。这个NPM模块可以帮助我们快速定位性能瓶颈。

问题

当负载较高时,某个后端模块的 响应时间慢 了很多,甚至出现 超时 错误”504 Gateway Time”。通过查看监控可知,这个模块在高峰期的CPU使用量是满负荷的,这有可能是问题所在。

接入Easy-Monitor

接入Easy-Monitor非常简单,在入口js文件中导入即可:

if (process.env.NODE_ENV === "development")
{
    const easyMonitor = require("easy-monitor");
    easyMonitor("backend");
}

启动应用,访问:http://localhost:12333/index,即可查看Easy-Monitor的UI界面:



采集CPU数据

ab 命令可以用于进行压力测试

ab -n 1000 -c 10  -T 'application/json' -p data.json http://localhost:3000/data/

运行ab测试的同时,在easy-monitor界面,选择cpu,然后start。easy-monitor就会默默地采集CPU数据,5分钟之后,就可以看到统计结果:



使用Fundebug,阔以及时发现并修复应用错误,赶紧免费试用吧!!!

修复性能问题

由Easy-Monitor的统计结果可知, 函数A是性能瓶颈 ,消耗了最多的CPU时间。

那么,剩下的工作就非常简单了,对函数A进行性能优化即可。经过分析,函数A进行了大量重复计算,增加2行代码就可以大大地优化其性能。具体细节不再赘述,因为不是本文重点。

优化前后的性能比较

根据ab命令的测试结果,优化前平均每秒处理 5.36 个,优化后这个数字变成了 48.35 ,是之前的 9倍 。将这个模块部署之后,服务器的CPU使用率大幅下降,接口的响应时间也恢复了正常。







请到「今天看啥」查看全文