浅析Linux追踪技术之kprobe:基于kprobes的Event Tracing

文章目录

概述

常规的Event Tracing(事件追踪)是通过散落在Linux内核代码各处的Tracepoint来实现的,这些Tracepoint数量有限,在出现问题时,往往不能覆盖到要追踪的函数;而利用kprobes机制,则可以实现对所有支持kprobes插入的代码点进行追踪。这种方式是 kprobe 和 ftrace 结合使用,通过 kprobe 来优化 ftrace 来跟踪函数的调用。

内核选项配置

为了使能基于kprobes进行Event Tracing,需要配置内核选项:CONFIG_KPROBE_EVENTS,如下:

ftrace配置接口

ftrace通过debugfs/tracefs提供配置接口,其中与kprobe相关的文件如下:

  • /sys/kernel/debug/tracing/kprobe_events:用于配置kprobe事件,新增的事件会在kprobes目录下生成对应的事件目录;
  • /sys/kernel/debug/tracing/events/kprobes/<EVENT>/enable:使能/禁用kprobes事件;
  • /sys/kernel/debug/tracing/kprobe_profile:kprobe事件统计

kprobe事件配置

kprobe使用/sys/kernel/debug/tracing/kprobe_events文件配置kprobe事件,设置方法如下:

  • 添加kprobe探测点:echo 'p[:[GRP/]EVENT] [MOD:]SYM[+offs]|MEMADDR [FETCHARGS]' > kprobe_events
  • 添加kretprobe探测点:echo 'r[:[GRP/]EVENT] [MOD:]SYM[+0] [FETCHARGS]' > kprobe_events
  • 删除指定的探测点:echo '-:[GRP/]EVENT' > kprobe_events
  • 删除所有的探测点:echo > kprobe_events

对于配置内容的各个字段解释如下:

  • GRP:Group名称,指定后会在events/kprobes/下生成目录;
  • EVENT:Event名称,指定后会在events/kprobes//下生成目录;
  • MOD:被探测的模块名;
  • SYM[+offs]:被探测的函数名以及偏移;
  • MEMADDR :指定被探测的内存地址;
  • FETCHARGS :获取参数信息
    • %REG:获取指定寄存器的值,REG取决于当前的处理器体系架构,如x86_64下,可以为rax、rsp等;
    • @ADDR:获取指定内存地址的值;
    • @SYM[+|-offs]:获取指定符号偏移内存的内容;
    • $stackN:获取第N个栈地址
    • $stack:获取栈地址;
    • $argN:获取第N个参数的值(N >= 1);
    • $retval:获取函数返回值,仅支持kretprobe探测点;
    • $comm:获取当前任务的comm字段值;

使用示例

添加kprobes事件

通过向kprobe_events文件写入指定格式的字符串,可以添加kprobes事件:

复制代码
echo 'p:kprobe_submit_bio submit_bio bio=%x0' > kprobe_events
echo 'r:kretprobe_submit_bio submit_bio ret=$retval' >> kprobe_events

添加事件完成后,cat kprobe_events可以看到新添加的kprobe事件:

同时在/sys/kernel/debug/tracing/events/kprobes/目录下,可以看到刚刚创建的两个kprobe trace evens:

kprobes事件使能

kprobe事件添加后,后面就可以按照trace events的方法来控制对应的事件了,如果要使能特定的kprobe事件:

复制代码
echo 1 > /sys/kernel/debug/tracing/events/kprobes/kprobe_submit_bio/enable
echo 1 > /sys/kernel/debug/tracing/events/kprobes/kretprobe_submit_bio/enable

通过/sys/kernel/debug/tracing/trace文件查看事件触发信息:

kprobes事件统计

kprobe可以通过/sys/kernel/debug/tracing/kprobe_profie查看kprobe事件触发的统计情况:

最后两列分别表示命中和未命中的次数。

参考链接

相关推荐
百***66172 小时前
linux上redis升级
linux·运维·redis
z***56562 小时前
Nginx(搭建高可用集群)
运维·nginx·firefox
小糖学代码3 小时前
网络:4.1加餐 - 进程间关系与守护进程
linux·网络
m***66733 小时前
【Sql Server】sql server 2019设置远程访问,外网服务器需要设置好安全组入方向规则
运维·服务器·安全
天草二十六_简村人3 小时前
docker安装index-tts,实现文本转语音的本地私有化部署
运维·docker·ai·容器·ai编程
xinxinhenmeihao3 小时前
隧道代理和住宅IP有何不同》各有什么优缺点?
服务器·网络·tcp/ip
观望过往3 小时前
Docker 全面技术指南:从基础概念到企业级应用实践
运维·docker·容器
小小测试开发3 小时前
JMeter高级用法全解析:从性能测试到自动化监控,解锁压测工具的隐藏实力
运维·jmeter·自动化
小兔薯了4 小时前
6. Linux 硬盘分区管理
linux·运维·服务器
努力的Andy4 小时前
Linux 云服务器新增硬盘:从分区、格式化到挂载的完整指南
linux·运维·服务器