在OR项目中使用火焰图

火焰图介绍

看到openresty里用火焰图以为挺有意思的,又装逼又有用。它能够快速的定位到程序性能的瓶颈,生成程序的调用栈而且计算调用栈中每部分的 CPU 消耗,可以比较容易的找到CPU占用高、内存泄漏等问题。今天在本身之前的项目中测试了下,下面贴个图留个记念。
![图片描述nginx

这里面不要看颜色,由于颜色是随机搞来的,没有任何意义。要看火焰山上纵向的高度和每一个对应的长度。纵向的高度表明函数调用栈的深度,横向长度表明此函数执行占用CPU的比例。git

下面来了解下火焰图工具如何安装。github

火焰图安装

参考 http://kernelmaker.github.io/...svg

安装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() }'

若是安装成功则是这样
clipboard.png性能

下载 openresty-systemtap-toolkit

要知道systemtap只是个内核探测工具,不仅是能够用在openresty中的,你得本身写好脚原本进行埋点等工做。可是春哥已经在 openresty-systemtap-toolkit 中提供了许多能够直接使用的脚本,咱们直接拿过来用就行了,毕竟我本身是不会写的。测试

下载 FlameGraph

使用上面openresty-systemtap-toolkit这些脚本后,咱们其实已经能够拿到咱们所须要的信息了,只是仍是不够直观,因此咱们得用FlameGraph火焰图生成工具来生成直观的图片。lua

使用示例

1.找到咱们要监控的nginx的某个进程
ps -ef | grep nginxspa

clipboard.png

2.ngx-sample-lua-bt 抓取栈信息(这个工具能够看到在某个文件对应行函数的状况)
此处我是把上面下载的openresty-systemtap-toolkitFlameGraph加到环境变量里面去了。因此直接输入命令就好了

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.cbt
flamegraph.pl a.cbt > a.svg

而后打开a.svg就能够看到火焰图了

相关文章
相关标签/搜索