什么是火焰图
火焰图整个图形看起来就像一个跳动的火焰,这就是它名字的由来。
- 每一列代表一个调用栈,每一个格子代表一个函数;
- 纵轴展示了栈的深度,按照调用关系从下到上排列,最顶上格子代表采样时,正在占用 cpu 的函数;
- 横轴格子的宽度代表其在采样中出现频率,所以一个格子的宽度越大,说明它是瓶颈原因的可能性就越大;
- 火焰图格子的颜色是随机的暖色调,方便区分各个调用信息;
- 其他的采样方式也可以使用火焰图, on-cpu 火焰图横轴是指 cpu 占用时间,off-cpu 火焰图横轴则代表阻塞时间;
- 采样可以是单线程、多线程、多进程甚至是多 host
火焰图展现的一般是从进程(或线程)的堆栈中采集来的数据,即函数之间的调用关系。从堆栈中采集数据有很多方式,下面是几种常见的采集工具:
- eBPF
- SystemTap
- Performance Event
- DTrace
- Gprof
火焰图类型
常见的火焰图类型有 On-CPU,Off-CPU,还有 Memory,Hot/Cold,Differential 等等。他们分别适合处理什么样的问题呢?