perf & 火焰图

安装

  • perf
sudo yum install -y perf
  • 火焰图

        到gitee中搜索一个火焰图的国内仓库

git clone git@gitee.com:wrran/FlameGraph.git

Step.1 编译运行要测试的程序

//   gcc -o test_flame test_flame.c
#include <fcntl.h>
#include <stdio.h>
#include <unistd.h>
int main()
{
	int fd = open("./file.txt", O_CREAT | O_RDWR);

	if (fd < 0)
	{
		printf("fd: %d\n", fd);
	}
	while (1)
	{

		char buf[8] = "xxxxxxx";
		int w_size = write(fd, buf, 8);
		char buf2[8];
		read(fd, buf2, 8);
	}
	return 0;
}

Step.2 使用命令生成perf.data数据 

sudo ./gen_graph.sh 
# 清理数据
rm -f ./perf.data ./perf.data.old ./perf.svg ./perf.unfold ./per.folded

#1. perf 抓取数据
perf record -F 99 -a -g -p `pidof test_flame` -- sleep 2

#2. perf script 对perf.data进行解析
perf script -i perf.data &> perf.unfold

#3. 符号折叠
FlameGraph/stackcollapse-perf.pl perf.unfold &> perf.folded

#4. 生成火焰图
FlameGraph/flamegraph.pl perf.folded > perf.svg

 perf

-F 99 :1秒钟进行采集99次
-a:采集所有cpus信息
-g:收集调用栈
-- sleep 30:采集时间为30秒
-t:收集的线程id
-p: 收集的进程id

Step.3 生成的perf.svg

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值