1. ftrace是什么
ftrace是内核的跟踪器。可追踪插件追踪内核事件。
ftrace的用户界面是在debugfs文件系统上生成的。多数情况下挂载到/sys/kernel/debug目录下
对应挂载命令“mount -t debugfs debugfs /sys/kernel/debug”。 ftrace目录为/sys/kernel/debug/tracing,下面有ftrace控制相关的文件。
data:image/s3,"s3://crabby-images/9fec1/9fec12dba200d7c8fc066303272be8e6d54390bf" alt=""
2. 使用ftrace
使用举例如下:
a. 追踪函数调用
data:image/s3,"s3://crabby-images/702c1/702c161f0f8ab9c071922945bfd387e7d9969414" alt=""
上面看出,进程调用程序是从几个不同的函数调用的。
b. 使用通配符追踪多个函数
data:image/s3,"s3://crabby-images/3636f/3636ff093fc6d50d6a51402e0562133799522a40" alt=""
上面结果记录了以irq开头的函数。
c. 追踪指定模块中的函数
data:image/s3,"s3://crabby-images/0a941/0a941b226513f81fd4604049415ba2e5635b04ed" alt=""
d. 获取函数的调用关系
data:image/s3,"s3://crabby-images/a2537/a253791b7a9cd3ebb03df6763162b6b4b8b6422f" alt=""
上图中使用缩进和大括号清晰的显示调用关系。
e. 函数回溯
data:image/s3,"s3://crabby-images/007dc/007dcbd53e9de805c6ee62ec73aa4131db341f70" alt=""
上图中对象函数的追踪入口后面出现了,它的后面显示的是回溯的结果。
f. 进行函数概要分析
data:image/s3,"s3://crabby-images/e2ac7/e2ac742789c746e776bedd67f3d15e334414387c" alt=""
上图中,Time表示累计值,Avg表示平均值,S^2表示平均方差。其中值包含函数内休眠时间,和函数内调用其它函数的处理时间。
这此时间可以分别用options/sleep-time和options/graph-time来修正。
修正睡眠时间
data:image/s3,"s3://crabby-images/72c89/72c8943b4556d6d1a8ea1882caccbd9bf0861752" alt=""
修正调用其它函数的时间
data:image/s3,"s3://crabby-images/8a2c2/8a2c2e2419d9dba56a418fbf8edbdf062215eed3" alt=""
g. 查找占用内核栈最大的位置
data:image/s3,"s3://crabby-images/ed81f/ed81f00527b1e066b758215d2d8cef44350101ef" alt=""
上图Depth表示该函数内最大的栈消耗量, Size表示仅该函数内的栈消耗量
h. 测量中断延迟
echo irqsoff > current_tracer
echo 1 > tracing_on
echo 0 > tracing_on
cat trace
当前环境不支持
i. 记录内核事件
data:image/s3,"s3://crabby-images/bfbd5/bfbd504ec61bb8f1ecd5cafdce9aac9c21e3eb8a" alt=""
上图看出,不同任务处理时发生中断
j. 查看特定中断
删除过滤如下
data:image/s3,"s3://crabby-images/89510/895105305831892f7861f76990de6d8af16639db" alt=""
k. 查看可追踪事件
/sys/kernel/debug/tracing/available_events文件中的内容为可追踪事件
/sys/kernel/debug/tracing/events目录下为各追踪事件组名和事件名。如下:
阅读(1632) | 评论(0) | 转发(0) |