zoukankan      html  css  js  c++  java
  • [转]perf + 火焰图分析程序性能

    1、perf命令简要介绍

    性能调优时,我们通常需要分析查找到程序百分比高的热点代码片段,这便需要使用 perf record 记录单个函数级别的统计信息,并使用 perf report 来显示统计结果;

    perf record
    
    perf report

    举例:

    sudo perf record -e cpu-clock -g -p 2548

    -g 选项是告诉perf record额外记录函数的调用关系

    -e cpu-clock 指perf record监控的指标为cpu周期

    -p 指定需要record的进程pid

    程序运行完之后,perf record会生成一个名为perf.data的文件,如果之前已有,那么之前的perf.data文件会被覆盖

    获得这个perf.data文件之后,就需要perf report工具进行查看

    perf report -i perf.data

    -i 指定要查看的文件

     以诊断mysql为例,report结果:

    $sudo perf report  -i perf.data

    这种格式很不直观

     2、使用火焰图展示结果

    1、Flame Graph项目位于GitHub上:https://github.com/brendangregg/FlameGraph

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

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

    1、第一步

    $sudo perf record -e cpu-clock -g -p 28591

    Ctrl+c结束执行后,在当前目录下会生成采样数据perf.data.

    2、第二步

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

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

    3、第三步

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

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

    4、最后生成svg图:

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

     
    分类: Linux
  • 相关阅读:
    Redis 连接
    Redis 脚本
    Redis 事务
    Redis 发布订阅
    redis 字符串数据(string)
    Redis 键(key)
    Redis 命令
    Redis的五种数据类型
    java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory 解决方案
    在命令行中运行eclipse中创建的java项目
  • 原文地址:https://www.cnblogs.com/wlzy/p/9787447.html
Copyright © 2011-2022 走看看