一、火焰图
一、下载 FlameGraph
git clone https://github.com/brendangregg/FlameGraph.git
FlameGraph 介绍:
基本思想是将程序的函数调用栈转化为一个矩形的 “火焰” 形图像,每个矩形的宽度表示该函数所占用的比例,高度表示函数的调用深度(也就是递归调用的层数)。通过比较不同时间点的火焰图,可以快速诊断程序的性能瓶颈所在,从而针对性地进行优化。通常情况下,如果遇到栈顶上存在很宽的矩形,那么这个函数就是性能瓶颈,需要重点分析优化
二、安装 iperf
sudo apt install linux-tools-common
在终端输入perf version
,根据显示的报错来安装对应的Package
如上,当前ubuntu系统需要运行如下指令进行安装:
sudo apt-get install linux-tools-6.5.0-18-generic linux-cloud-tools-6.5.0-18-generic
三、使用
cd FlameGraph
## -p 826526 表示正在监控 PID 为 826526 的进程
## -F 99 表示采样频率设置为每99个CPU周期记录一次
## -a 表示记录所有CPU上面的数据
## -g 启用函数级别的调用图记录、记录每个函数调用的堆栈信息
## -- 这个符号用于分隔 perf record 的参数和接下来要运行的命令
## sleep 60 表示在运行完perf record后等待60s来生成一些性能数据
sudo perf record -F 99 -a -g -- sleep 60
perf script > out.perf
./stackcollapse-perf.pl out.perf > out.folded
./flamegraph.pl out.folded> out.svg
显示采样的数据
sudo perf report
二、Lockdep
1、内核开启 Lockdep 配置
CONFIG_LOCK_STAT=y
CONFIG_PROVE_LOCKING=y
CONFIG_DEBUG_LOCKDEP=y
2、判断 Lockdep 开启是否成功
cat /proc/lockdep
如果出现了 lockdep lockdep_chains lockdep_stats
这三个文件,即说明开启成功