ubuntu性能分析-ftrace 的使用

本文介绍了如何在Ubuntu系统中使用ftrace进行性能分析,重点讲解了ftrace的文件接口和Tracers,包括直接使用ftrace命令以及利用trace-cmd和kernelshark这两个工具进行记录和分析。trace-cmd的编译安装、使用方法及其命令行选项,如record、show等,以及kernelshark的事件记录、结果分析等功能被详细阐述。文章还提醒了使用trace-cmd record时正确发送ctrl+c停止记录的注意事项。
摘要由CSDN通过智能技术生成

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。

        trace采集数据的手段归根到底就两种:插桩、采样。ftrace是插桩法的集大成者,各种trace为了插桩使出了浑身解数给出了花样百变的插桩方法。

2、ftrace 文件接口

        ftrace挂载在debugfs上,当前android系统中默认已经挂载了,不过为了方便,我这里首先基于ubuntu使用,后面在介绍

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值