Perfetto项目快速入门:Linux系统追踪指南
前言
Perfetto是Google开发的一款高性能系统性能分析工具,专门用于收集和分析系统级追踪数据。本文将详细介绍如何在Linux系统上使用Perfetto进行系统追踪,从源码编译到最终的数据可视化分析。
环境准备
在开始之前,请确保你的Linux系统满足以下要求:
- 具备基本的开发工具链(如gcc、make等)
- 安装了git版本控制工具
- 网络连接正常(用于下载依赖)
源码编译步骤
1. 获取源码
首先需要获取Perfetto的源代码:
git clone https://github.com/google/perfetto.git && cd perfetto
2. 安装构建依赖
Perfetto提供了便捷的脚本来自动安装构建依赖:
tools/install-build-deps
如果遇到SSL相关错误,建议升级系统的openssl包。
3. 生成构建配置
使用GN工具生成构建配置:
tools/gn gen --args='is_debug=false' out/linux
对于更复杂的构建需求,可以使用tools/setup_all_configs.py
脚本生成更多构建配置。
4. 编译关键组件
编译Linux追踪相关的二进制文件:
tools/ninja -C out/linux tracebox traced traced_probes perfetto
编译过程会使用在第二步下载的clang工具链。
追踪数据采集
Perfetto采用服务化架构设计,需要同时运行多个组件才能完成追踪数据的采集。
基础追踪模式
对于只需要系统级追踪(如ftrace和/proc轮询)的场景,可以使用tracebox
的自动启动模式:
out/linux/tracebox -o trace_file.perfetto-trace --txt -c test/configs/scheduling.cfg
这个命令会生成一个包含调度信息的追踪文件。
高级追踪模式(系统模式)
如果需要结合应用自定义的追踪事件,需要手动启动各个服务组件:
- 使用便利脚本启动服务(10秒持续时间):
tools/tmux -c test/configs/scheduling.cfg -C out/linux -n
-
在tmux窗口的最下方面板执行预填充的
perfetto
命令开始追踪 -
使用
Ctrl-B D
退出tmux会话,或使用tmux kill-session -t demo
终止会话
追踪文件默认保存在/tmp/trace.perfetto-trace
,采用二进制编码的protobuf格式。
追踪数据分析
Perfetto提供了强大的Web界面来分析追踪数据。
可视化分析步骤
-
在浏览器中打开Perfetto UI
-
点击左侧菜单的"Open trace file",加载之前生成的追踪文件
-
使用以下操作探索数据:
- WASD键进行缩放和平移
- 鼠标点击展开进程轨道查看线程详情
- 按"?"键查看完整的导航控制说明
高级分析功能
除了可视化界面,Perfetto还提供了通过SQL查询分析追踪数据的能力,这需要使用trace processor工具。
技术要点解析
-
ftrace集成:Perfetto通过ftrace接口从Linux内核获取调度等系统事件数据
-
服务架构:
traced
:会话守护进程traced_probes
:探针和ftrace交互守护进程perfetto
:命令行客户端
-
数据格式:追踪数据采用protobuf二进制格式存储,兼顾效率和扩展性
常见问题解决
- SSL错误:升级系统openssl包
- 构建失败:确保所有依赖已正确安装
- 追踪文件损坏:检查磁盘空间和权限设置
结语
通过本指南,你应该已经掌握了在Linux系统上使用Perfetto进行系统性能分析的基本流程。Perfetto强大的追踪能力和灵活的分析工具使其成为系统性能调优的利器。建议从简单的调度分析开始,逐步探索更复杂的追踪场景和分析方法。
创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考