性能工具之 FlameGraph 火焰图
【摘要】 很多人觉得火焰图炫酷,如果只从操作上来说,真是没什么难度,只比大象放冰箱稍微难点。这里演示一下 perf 结果怎么放冰箱,不,是怎么生成火焰图!
前言
很多人觉得火焰图炫酷
如果只从操作上来说,真是没什么难度,只比大象放冰箱稍微难点
这里演示一下 perf 结果怎么放冰箱,不,是怎么生成火焰图!
演示操作
第一步:随便录点啥,我这里是所有操作,主要是生成 perf.data
文件
[root@7DGroup FlameGraph]# perf record -F 99 -a -g -- sleep 60
[ perf record: Woken up 7 times to write data ]
[ perf record: Captured and wrote 1.868 MB perf.data (11880 samples) ]
[root@7DGroup FlameGraph]# ll
total 1924
drwxr-xr-x 7 root root 4096 Mar 4 07:42 FlameGraph
-rw------- 1 root root 1965540 Mar 4 08:45 perf.data
第二步:转换成输出文件
[root@7DGroup FlameGraph]# perf script > out.perf
[root@7DGroup FlameGraph]# ll
total 7460
drwxr-xr-x 7 root root 4096 Mar 4 07:42 FlameGraph
-rw-r--r-- 1 root root 5668491 Mar 4 08:46 out.perf
-rw------- 1 root root 1965540 Mar 4 08:45 perf.data
第三步:折叠栈信息
[root@7DGroup FlameGraph]# ./FlameGraph/stackcollapse-perf.pl out.perf > out.folded
[root@7DGroup FlameGraph]# ll
total 7576
drwxr-xr-x 7 root root 4096 Mar 4 07:42 FlameGraph
-rw-r--r-- 1 root root 115637 Mar 4 08:47 out.folded
-rw-r--r-- 1 root root 5668491 Mar 4 08:46 out.perf
-rw------- 1 root root 1965540 Mar 4 08:45 perf.data
第四步:生成SVG文件
[root@7DGroup FlameGraph]# ./FlameGraph/flamegraph.pl out.folded > kernel.svg
[root@7DGroup FlameGraph]# ll
total 7732
drwxr-xr-x 7 root root 4096 Mar 4 07:42 FlameGraph
-rw-r--r-- 1 root root 157603 Mar 4 08:48 kernel.svg
-rw-r--r-- 1 root root 115637 Mar 4 08:47 out.folded
-rw-r--r-- 1 root root 5668491 Mar 4 08:46 out.perf
-rw------- 1 root root 1965540 Mar 4 08:45 perf.data
[root@7DGroup FlameGraph]#
第五步:下载并打开 svg 文件
小结
其实很多类似 perf 的工具都能生成火焰图,像 systemtap/dtrace 之类的
并且这个思路,现在在 js 优化、代码优化等各方面都有具体的应用了
至于怎么理解?
简单点说,就是看谁又平又宽
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)