什么是火焰图

    火焰图整个图形看起来就像一个跳动的火焰,这就是它名字的由来。

    • 每一列代表一个调用栈,每一个格子代表一个函数;
    • 纵轴展示了栈的深度,按照调用关系从下到上排列,最顶上格子代表采样时,正在占用 cpu 的函数;
    • 横轴格子的宽度代表其在采样中出现频率,所以一个格子的宽度越大,说明它是瓶颈原因的可能性就越大;
    • 火焰图格子的颜色是随机的暖色调,方便区分各个调用信息;
    • 其他的采样方式也可以使用火焰图, on-cpu 火焰图横轴是指 cpu 占用时间,off-cpu 火焰图横轴则代表阻塞时间;
    • 采样可以是单线程、多线程、多进程甚至是多 host

    火焰图展现的一般是从进程(或线程)的堆栈中采集来的数据,即函数之间的调用关系。从堆栈中采集数据有很多方式,下面是几种常见的采集工具:

    • eBPF
    • SystemTap
    • Performance Event
    • DTrace
    • Gprof

    火焰图类型

    常见的火焰图类型有 On-CPU,Off-CPU,还有 Memory,Hot/Cold,Differential 等等。他们分别适合处理什么样的问题呢?

    什么是火焰图 - 图2