使用perf抓取火焰图

这里我搞了一个perf脚本,方便抓取火焰图,有些时候就算不高c/c++开发抓取火焰图还是非常必要的,比如说你某个构建运行时间很久,想要分析下原因,都可以使用这个!

注意: perf 仅支持linux 环境!

脚本

shell 复制代码
#!/usr/bin/env bash

set -e

function usage() {
    echo "Usage:"
    echo "  $(basename $0) [-F req] [-p pid]"
    echo "  $(basename $0) [-F req] [binary]"
    echo "注意: -F 默认是 /proc/sys/kernel/perf_event_max_sample_rate 的值"
}

FlameGraph_home="${HOME}/go/src/github.com/brendangregg/FlameGraph"

if [ -z "$1" ]; then
    usage
    exit 1
fi

if [ ! -d "$FlameGraph_home" ]; then
    mkdir -p "$(dirname "$FlameGraph_home")"
    git clone --depth 1 https://github.com/brendangregg/FlameGraph.git "$FlameGraph_home"
fi

output_file=$(date '+%Y%m%d%H%M%S')
process_output_perf="output/${output_file}.data"
process_output_svg="output/${output_file}.svg"
function parse_perf() {
    echo "proccess done...."
    perf script -i "$process_output_perf" | "$FlameGraph_home"/stackcollapse-perf.pl | "$FlameGraph_home"/flamegraph.pl >"${process_output_svg}"
    echo "open ${process_output_svg}"
}

# 移除文件
rm -rf "$process_output_perf"
rm -rf "$process_output_svg"

mkdir -p output

# 结束的时候
trap parse_perf EXIT

set -x

perf record -o "$process_output_perf" -g "$@"

使用

  • 开启抓取
shell 复制代码
./perf.sh -F 10000 -p <PID>
  • 关闭抓取: ctrl + c

  • 结束后会生成一个csv, 效果如下

相关推荐
Mahir086 小时前
Spring 循环依赖深度解密:从问题本质到三级缓存源码级解析
java·后端·spring·缓存·面试·循环依赖·三级缓存
小鹏linux7 小时前
Ubuntu 22.04 部署开源免费具有精美现代web页面的Casdoor账号管理系统
linux·前端·ubuntu·开源·堡垒机
在角落发呆8 小时前
Linux转发配置:解锁网络互联的核心密码
linux·运维·网络
齐潇宇8 小时前
Zabbix 7 概述与配置
linux·zabbix·监控告警
江公望9 小时前
Ubuntu htop命令,10分钟讲清楚
linux·服务器
哎呦,帅小伙哦9 小时前
Linux 时间:从原子钟到 clock_gettime 的每一面
linux·运维·服务器
张小姐的猫10 小时前
【Linux】多线程 —— 线程互斥
linux·运维·服务器·c++
IT_陈寒10 小时前
Redis缓存击穿把我整不会了,原来还有这手操作
前端·人工智能·后端
YuanDaima204810 小时前
Linux 进阶运维与 AI 环境实战:进程管理、网络排错与 GPU 监控
linux·运维·服务器·网络·人工智能
kyriewen11 小时前
面试官让我查各部门工资最高的员工,我用AI三秒写出窗口函数,他愣了
后端·mysql·面试