1、概述
在日常工作中,经常会需要对内核进行Debug、或者进行优化工作。一些简单的问题,可以通过dmesg/printk查看,优化借助一些工具进行。但是当问题逻辑复杂,优化面宽泛的时候,往往无从下手。需要从上到下、模块到模块之间分析,这时候就不得不借助于Linux提供的静态(Trace Event)动态(各种Tracer)进行分析。同时还不得不借助工具、或者编写脚本进行分析,以缩小问题范围、发现问题。直接拿printk和Trace作对比可能并不太合适,因为他们针对不同的使用场景,但是不管什么方法,能解决问题才是王道~。
ftrace 是 Function Trace 的简写,由 Steven Rostedt 开发的,从 2008 年发布的内核 2.6.27 中开始就内置了。这是为记录数据提供的一个调试 Ring 缓冲区的框架。这些数据由集成到内核中的跟踪程序来采集,现在大概分为两大类:tracer、event。
- tracer。发展出了function tracer、function_graph tracer、irqsoff tracer、preemptoff tracer、wakeup tracer等一系列tracer。
- event。也发展出trace event、kprobe event、uprobe event、syscall event等一系列的event。
tr
本文介绍了如何在Ubuntu系统中使用ftrace进行性能分析,重点讲解了ftrace的文件接口和Tracers,包括直接使用ftrace命令以及利用trace-cmd和kernelshark这两个工具进行记录和分析。trace-cmd的编译安装、使用方法及其命令行选项,如record、show等,以及kernelshark的事件记录、结果分析等功能被详细阐述。文章还提醒了使用trace-cmd record时正确发送ctrl+c停止记录的注意事项。
订阅专栏 解锁全文
2013





