perf&&FlameGraph&Pyroscope火焰图展示结果

本文详细介绍如何使用perf工具结合火焰图分析程序性能。通过具体步骤演示如何收集、解析及生成可视化的性能数据,帮助读者深入理解程序运行状况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

perf + 火焰图分析程序性能https://www.cnblogs.com/happyliu/p/6142929.html
如何读懂火焰图?http://www.ruanyifeng.com/blog/2017/09/flame-graph.html
perf与火焰图使用介绍https://blog.csdn.net/xuhaitao23/article/details/124016932

一、可以用git将其clone下来:git clone https://github.com/brendangregg/FlameGraph.git

yum install git  perf -y
git clone https://github.com/brendangregg/FlameGraph.git 

我们以perf为例,看一下flamegraph的使用方法:

1、第一步

perf record -e cpu-clock -g -p pid 
#Ctrl+c结束执行后,在当前目录下会生成采样数据perf.data.

或者

#采集300秒
perf record -F 99 -p $pid -g -- sleep 300

2、第二步

用perf script工具对perf.data进行解析

perf script -i perf.data &> perf.unfold

3、第三步

将perf.unfold中的符号进行折叠:

FlameGraph/stackcollapse-perf.pl perf.unfold &> perf.folded

4、最后生成svg图:

FlameGraph/flamegraph.pl perf.folded > perf.svg

5、一个例子

#!/bin/bash
pid=$1
perf record -F 99 -p $pid -g -- sleep 60
perf script > out.perf
./stackcollapse-perf.pl out.perf > out.folded
./flamegraph.pl out.folded > out.svg

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值