摘要: 使用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使用率大幅下降,接口的响应时间也恢复了正常。
总结
使用Easy-Monitor,可以将性能瓶颈准确定位到某些函数,然后进行针对性的优化,这样可以帮助我们快速修复性能问题。
参考
感谢关注,我就是作者,其实线上真实使用还是建议上这个: Node.js 性能平台,能处理对大堆的分析和追踪,关键是免费啊,当时开发 easy-monitor 的时候有一个原因是 alinode 收费…
@hyj1991 谢谢推荐,我会研究一下。 easy-monitor我是在开发的时候用…
@Fundebug 嗯,alinode 可以在线上使用,我们已经给大量的开发者解决了许多奇奇怪怪的线上问题,可以关注下,有问题可以加钉钉群 11794270 讨论下,基本 24 小时都有人在的
不错回去试一下。
nice.回去就测试一下
来自酷炫的 CNodeMD
看来楼主很少逛论坛,EM的作者在论坛可是很活跃的
来自酷炫的 CNodeMD