火焰图介绍
看到openresty
里用火焰图觉得挺有意思的,又装逼又有用。它可以快速的定位到程序性能的瓶颈,生成程序的调用栈并且计算调用栈中每部分的 CPU
消耗,能够比较容易的找到CPU
占用高、内存泄漏等问题。今天在自己以前的项目中测试了下,下面贴个图留个纪念。
这里面不要看颜色,因为颜色是随机搞来的,没有任何意义。要看火焰山上纵向的高度和每个对应的长度。纵向的高度代表函数调用栈的深度,横向长度代表此函数执行占用CPU
的比例。
下面来了解下火焰图工具如何安装。
火焰图安装
参考
安装systemtap
其实主要就是安装内核探测工具 systemtap
。(SystemTap
通过将脚本语句翻译成C
语句,编译成内核模块。模块加载之后,依据时间处理机制来收集有关正在运行的Linux
系统的信息)
1. yum install yum-utils 2. yum install kernel-devel 3. debuginfo-install kernel 4. yum install systemtap
第三步安装失败的话,使用内核版本号找到对应的包进行安装就好了。
完成后输入以下命令进行测试stap -ve 'probe begin { log("hello world") exit() }'
如果安装成功则是这样
下载
要知道systemtap
只是个内核探测工具,不只是可以用在openresty
中的,你得自己写好脚本来进行埋点等工作。但是春哥已经在 openresty-systemtap-toolkit
中提供了许多可以直接使用的脚本,我们直接拿过来用就好了,毕竟我自己是不会写的。
下载
使用上面openresty-systemtap-toolkit
这些脚本后,我们其实已经可以拿到我们所需要的信息了,只是还是不够直观,所以我们得用FlameGraph
火焰图生成工具来生成直观的图片。
使用示例
1.找到我们要监控的nginx
的某个进程
ps -ef | grep nginx
2.ngx-sample-lua-bt
抓取栈信息(这个工具可以看到在某个文件对应行函数的情况)
openresty-systemtap-toolkit
和FlameGraph
加到环境变量里面去了。所以直接输入命令就行了 ngx-sample-lua-bt -p 19075 --luajit20 -t 5 > temp.bt
3.使用fix-lua-bt
把上面得到的文件转化更友好点(直接看到对应的lua
函数)
fix-lua-bt temp.bt > a.bt
4.使用下面两个FlameGraph
中的命令将文件转化为svg
图片
stackcollapse-stap.pl a.bt > a.cbtflamegraph.pl a.cbt > a.svg
然后打开a.svg
就可以看到火焰图了