概述
perf(Performance Event)是Linux 2.6.31版本后,内核自带的强力性能分析工具。
火焰图是一种图表,将perf抓取的数据生成火焰图,可以使数据更直观,方便分析。
安装perf和Flame Graph
安装perf:
yum install perf
安装Flame Graph:
wget https://github.com/brendangregg/FlameGraph/archive/master.zip
unzip FlameGraph-master.zip
使用Flame Graph生成火焰图
1.perf需要先对目标进程进行采样。
语法格式:
./perf record -F 1000 -p [进程pid] -g
其中:
-F 指定采样的频率为1000Hz,即一秒钟采样1000次
-p 指定要采样的进程ID
-g 表示记录调用栈信息
打印结果:
[root@vdb1 ~]# perf record -F 99 -p 1203 -g -- sleep 30
[ perf record: Woken up 1 times to write data ]
[ perf record: Captured and wrote 0.393 MB perf.data (20 samples) ]
生成文件:
-rw------- 1 root root 417064 Jun 6 09:32 perf.data
2.对采样数据文件进行解析以生成堆栈信息。
在perf.data 目录下执行:
[root@vdb1 ~]# perf script > cpu.unfold
3.对perf.unfold进行符号折叠(可以将cpu.unfold拷贝到Flame Graph目录下执行)。
[root@vdb1 ~]# cp cpu.unfold /app/FlameGraph-master/
[root@vdb1 ~]# cd /app/FlameGraph-master/
[root@vdb1 FlameGraph-master]# ./stackcollapse-perf.pl cpu.unfold > cpu.folded
4.生成SVG格式的火焰图。
./flamegraph.pl cpu.folded > cpu.svg
然后下载文件,使用浏览器打开 svg 文件即可。
如果想知道某部分占比,可直接浏览器中搜索,会输出占比总和。
参考:
https://blog.csdn.net/qq_37437983/article/details/137299869
https://blog.csdn.net/Oliviahome/article/details/143360987