性能测试工具之perf
perf是什么?
系统原生提供的性能分析工具,会返回 CPU 正在执行的函数名以及调用栈(stack),如果使用的环境中没有这个命令,首先要安装。
它不但可以分析制定应用程序的性能问题(per thread),也可以用来分析内核的性能问题,当然也可以同时分析应用程序和内核,从而全面理解应用程序中的性能瓶颈
火焰图
# git clone https://github.com/brendangregg/FlameGraph.git
火焰图含义
y 轴表示调用栈,每一层都是一个函数。调用栈越深,火焰就越高,顶部就是正在执行的函数,
下方都是它的父函数。
x 轴表示抽样数,如果一个函数在 x 轴占据的宽度越宽,就表示它被抽到的次数多,即执行的时
间长。注意,x 轴不代表时间,而是所有的调用栈合并后,按字母顺序排列的。
火焰图就是看顶层的哪个函数占据的宽度最大。只要有"平顶"(plateaus),就表示该函数可能
存在性能问题。 颜色没有特殊含义,因为火焰图表示的是 CPU 的繁忙程度,所以一般选择暖色调
火焰图操作
鼠标悬浮
把鼠标放在某个函数上