Android上如何使用perfetto分析systrace
Android上如何使用perfetto分析systrace
Perfetto 是一个用于性能分析的工具,提供了对 Android 系统内部工作情况的详细视图。它可以用来替代传统的 systrace 工具,提供更加全面的性能分析功能。以下是如何使用 Perfetto 分析 Systrace 数据的详细指南,包括安装、收集、查看和分析 trace 的步骤。
1. 安装 Perfetto 工具
a. 在开发机器上安装 Perfetto
在开发环境中,需要安装 Perfetto 工具。可以从 GitHub 发布页面下载最新版本:
-
下载最新的 Perfetto 二进制文件:Perfetto Releases
-
下载并解压:
wget https://github.com/google/perfetto/releases/download/v<version>/perfetto-linux-x64.zip
unzip perfetto-linux-x64.zip
-
替换
<version>为最新的版本号,例如v24.0.0。
b. 在 Android 设备上安装 Perfetto
Perfetto 通常已内置在 Android 设备中,但如果需要手动安装,可以使用 adb 命令安装最新的 APK:
adb install -r perfetto-<version>-android.apk
可以从 Perfetto Releases 中找到对应的 APK 文件。
2. 收集 Perfetto Trace 数据
a. 使用 ADB 收集 trace 数据
Perfetto 可以从命令行启动并收集 trace 数据。你可以通过以下命令启动 Perfetto trace 捕获:
adb shell perfetto -c /data/misc/perfetto-trace/config.pbtx -o /data/misc/perfetto-trace/trace.pb
-
-c选项指定配置文件路径。你需要一个 Perfetto 配置文件(.pbtxt格式)。 -
-o选项指定输出文件路径。这个文件将保存 trace 数据。
b. 示例 Perfetto 配置文件
可以创建一个简单的配置文件 config.pbtxt,内容如下:
# Perfetto Trace Configbuffers {size_kb: 10240
}data_sources {config {name: "linux.ftrace"ftrace_config {categories: ["*"]}}
}duration_ms: 60000
这个配置文件指定了一个 10MB 的 buffer 和一个 60 秒的 trace 采集时长,并收集所有 Ftrace categories 的数据。
c. 启动 Trace 捕获
在设备上执行以下命令来开始捕获 trace 数据:
adb shell perfetto -c /data/misc/perfetto-trace/config.pbtxt -o /data/misc/perfetto-trace/trace.pb
d. 停止 Trace 捕获
停止 trace 捕获可以通过结束 Perfetto 命令来实现:
adb shell pkill -SIGINT perfetto
3. 分析 Perfetto Trace 数据
a. 使用 Perfetto UI 分析 Trace
Perfetto 提供了一个 Web UI,用于加载和分析 trace 数据:
-
打开 Perfetto UI。
-
点击“Open a Trace”按钮,选择你之前保存的 trace 文件
trace.pb。 -
使用 UI 工具中的不同面板来查看 trace 数据,包括 CPU 活动、Ftrace 信息、Heap 使用等。
b. 使用命令行工具分析 Trace
也可以使用 perfetto 命令行工具生成 HTML 或 JSON 格式的 trace 报告:
./perfetto --txt-to-pb /path/to/config.pbtxt
./perfetto -i /data/misc/perfetto-trace/trace.pb -o /data/misc/perfetto-trace/trace.html
这将把 trace 数据从 .pb 文件转换为 .html 文件,可以在浏览器中查看。
c. 进行深度分析
在 Perfetto UI 中,你可以进行以下分析操作:
-
查看 Timeline:查看各个事件的时间线,理解系统行为。
-
分析 CPU 使用情况:查看 CPU 核心的使用情况,识别性能瓶颈。
-
分析 Ftrace 数据:查看 Ftrace 提供的内核事件数据,诊断系统问题。
-
检查系统调用:查看应用或系统调用的详细信息。
4. 高级分析和优化
a. 使用查询语言分析 Trace
Perfetto 支持 SQL 查询语言,可以对 trace 数据执行复杂的查询:
SELECT * FROM slice WHERE name = 'your_event_name'
b. 结合其他工具
Perfetto 可以与其他性能分析工具结合使用,比如 Android Studio Profiler、adb shell dumpsys 等,以获得更全面的性能数据。
c. 编写自定义脚本分析 Trace
可以编写 Python 脚本来解析和分析 Perfetto trace 数据。Perfetto 提供了 Python API 进行更深层次的数据处理。
-
示例:使用 Perfetto 分析 Systrace 数据
以下是一个完整的示例,从配置到分析 Systrace 数据的步骤:
# 1. 创建 Perfetto 配置文件
echo 'buffers { size_kb: 10240 } data_sources { config { name: "linux.ftrace" ftrace_config { categories: ["*"] } } } duration_ms: 60000' > config.pbtxt# 2. 启动 Trace 捕获
adb shell perfetto -c /data/misc/perfetto-trace/config.pbtxt -o /data/misc/perfetto-trace/trace.pb# 3. 停止 Trace 捕获
adb shell pkill -SIGINT perfetto# 4. 下载 trace 文件到本地
adb pull /data/misc/perfetto-trace/trace.pb .# 5. 使用 Perfetto UI 打开 trace 文件
./perfetto -i trace.pb -o trace.html# 6. 打开 trace.html 文件进行分析
open trace.html
通过以上步骤,可以使用 Perfetto 来高效地收集和分析 Android 系统中的 Systrace 数据,进行深入的性能诊断和优化。
参考文档
-
Perfetto 主页
-
Perfetto GitHub 页面
相关文章:
Android上如何使用perfetto分析systrace
Android上如何使用perfetto分析systrace Perfetto 是一个用于性能分析的工具,提供了对 Android 系统内部工作情况的详细视图。它可以用来替代传统的 systrace 工具,提供更加全面的性能分析功能。以下是如何使用 Perfetto 分析 Systrace 数据的详细指南&…...
React Hooks学习笔记
一、usestate的使用方法-初始化state函数 import React, { useState } from "react"; function App() {const [count, setCount] useState(0);return (<div><p>点击{count}次</p><button onClick{() > setCount(count 1)}>点击</bu…...
BGP第二日
上图为今日所用拓扑 ,其中R1和R4,R3和R5为EBGP邻居,R1和R3为IBGP邻居,AS200区域做OSPF动态路由 一.BGP建立邻居的六种状态 1.idle 空闲状态:建立邻居最初的状态 2.Connect 连接状态:在…...
rabbitmq集群创建admin用户之后,提示can access virtual hosts是No access状态
问题描述: 因业务需要使用的rabbitmq是3.7.8版本的,rabbitmq在3.3.0之后就允许使用guest账号的权限了,所以需要创建一个administrator标签的用户。 如下操作创建的用户: 创建完成之后就提示如下的报错: 注:…...
ARM功耗管理之多核处理器启动
安全之安全(security)博客目录导读 思考:SecureBoot?多核处理器启动流程?PSCI启动方式? 一般嵌入式系统使用的都是对称多处理器(Symmetric Multi-Processor, SMP)系统,包含了多个cpu, 这几个cp…...
java使用easypoi模版导出word详细步骤
文章目录 第一步、引入pom依赖第二步、新建导出工具类WordUtil第三步、创建模版word4.编写接口代码5.导出结果示例 第一步、引入pom依赖 <dependency><groupId>cn.afterturn</groupId><artifactId>easypoi-spring-boot-starter</artifactId><…...
Android 内部保持数据的方式
Android内部保持数据的方式主要有五种,每种方式都有其特定的用途和优点。以下是详细的介绍: SQLite数据库 定义:SQLite是一个轻量级的、跨平台的数据库,所有的信息都存储在单一文件内,占用内存小,并且支持…...
uniapp 表格,动态表头表格封装渲染
1.接口表格数据: {"headers": [{"label": "实例名","name": "v1","order": 1,"hide": false,"dateTypeValue": null},{"label": "所属科室","name&quo…...
beyond Compare连接 openWrt 和 VsCode
连接步骤总结 1. 新建会话 -> 文件夹比较 2.点击浏览文件夹 3.在弹出页面 配置 ftp 3.1)选中ftp 配置文件 3.2)选中ssh2 3.3)填写我们需要远端连接的主机信息 先点击连接并浏览 得到下方文件夹 弹出无效登录,说明需要密码 我们返回右键刚刚创建的新 …...
量化机器人能否识别市场机会?
量化机器人的设计和应用是为了通过高级算法和大数据分析,精确地识别和把握市场中的交易机会。这些机器人的能力不仅仅局限于执行预定的交易策略,更包括在复杂和快速变化的市场环境中识别利润机会。 首先,量化机器人能够处理和分析大量的市场…...
香橙派AIpro开发板评测:部署yolov5模型实现图像和视频中物体的识别
OrangePi AIpro 作为业界首款基于昇腾深度研发的AI开发板,自发布以来就引起了我的极大关注。其配备的8/20TOPS澎湃算力,堪称目前开发板市场中的顶尖性能,实在令人垂涎三尺。如此强大的板子,当然要亲自体验一番。今天非常荣幸地拿到…...
MongoDB教程(二):mongoDB引用shell
💝💝💝首先,欢迎各位来到我的博客,很高兴能够在这里和您见面!希望您在这里不仅可以有所收获,同时也能感受到一份轻松欢乐的氛围,祝你生活愉快! 文章目录 引言一、MongoD…...
A133 Android10 root修改
1.前言 客户应用需求root相关的权限,我们需要修改系统的权限才可以满足客户需求 2.修改方法 frameworks层:注释掉 diff --git a/frameworks/base/core/jni/com_android_internal_os_Zygote.cpp b/frameworks/base/core/jni/com_android_internal_os_…...
实验场:在几分钟内使用 Bedrock Anthropic Models 和 Elasticsearch 进行 RAG 实验
作者:来自 Elastic Joe McElroy, Aditya Tripathi 我们最近发布了 Elasticsearch Playground,这是一个新的低代码界面,开发人员可以通过 A/B 测试 LLM、调整提示(prompt)和分块数据来迭代和构建生产 RAG 应用程序。今天…...
代理详解之静态代理、动态代理、SpringAOP实现
1、代理介绍 代理是指一个对象A通过持有另一个对象B,可以具有B同样的行为的模式。为了对外开放协议,B往往实现了一个接口,A也会去实现接口。但是B是“真正”实现类,A则比较“虚”,他借用了B的方法去实现接口的方法。A…...
Laravel - laravel-websockets 开发详解
1.我laravel-websockets 的开发环境 Laravel 9.0Laravel WebSockets (最新版)Laravel Vite 2. 安装服务器端包 beyondcode/laravel-websockets 运行以下命令安装laravel-websockets composer require beyondcode/laravel-websockets 安装完后&#…...
vue3 学习笔记04 -- axios的使用及封装
vue3 学习笔记04 – axios的使用及封装 安装 Axios 和 TypeScript 类型定义 npm install axios npm install -D types/axios创建一个 Axios 实例并封装成一个可复用的模块,这样可以在整个应用中轻松地进行 API 请求管理。 在 src 目录下创建一个 services 文件夹&…...
键盘快捷键设置录入
效果图: 代码: import React, {useContext, useEffect, useRef} from react import {message} from "antd"; import lodash from "lodash"; import {StateContext} from ../../index.tsx import {useUpdateEffect} from "ahoo…...
刷题Day49|647. 回文子串、516.最长回文子序列
647. 回文子串 647. 回文子串 - 力扣(LeetCode) 思路:递推公式的含义是[i, j]内的子串是否为回文子串(bolean[][])。一共两种情况:s[i] s[j],i和j相差1以外就得判断中间包含的的字符串是否为回文了&…...
关于transformers库验证时不进入compute_metrics方法的一些坑
生成式任务输入就是标签 transformers在进入compute_metrics前会有一个判断,源码如下: # 版本 transformers4.41.2 # 在trainer.py 的 3842 行 # Metrics! if (self.compute_metrics is not Noneand all_preds is not Noneand all_labels is not Nonea…...
linux之kylin系统nginx的安装
一、nginx的作用 1.可做高性能的web服务器 直接处理静态资源(HTML/CSS/图片等),响应速度远超传统服务器类似apache支持高并发连接 2.反向代理服务器 隐藏后端服务器IP地址,提高安全性 3.负载均衡服务器 支持多种策略分发流量…...
Spring Boot 实现流式响应(兼容 2.7.x)
在实际开发中,我们可能会遇到一些流式数据处理的场景,比如接收来自上游接口的 Server-Sent Events(SSE) 或 流式 JSON 内容,并将其原样中转给前端页面或客户端。这种情况下,传统的 RestTemplate 缓存机制会…...
Python:操作 Excel 折叠
💖亲爱的技术爱好者们,热烈欢迎来到 Kant2048 的博客!我是 Thomas Kant,很开心能在CSDN上与你们相遇~💖 本博客的精华专栏: 【自动化测试】 【测试经验】 【人工智能】 【Python】 Python 操作 Excel 系列 读取单元格数据按行写入设置行高和列宽自动调整行高和列宽水平…...
可靠性+灵活性:电力载波技术在楼宇自控中的核心价值
可靠性灵活性:电力载波技术在楼宇自控中的核心价值 在智能楼宇的自动化控制中,电力载波技术(PLC)凭借其独特的优势,正成为构建高效、稳定、灵活系统的核心解决方案。它利用现有电力线路传输数据,无需额外布…...
YSYX学习记录(八)
C语言,练习0: 先创建一个文件夹,我用的是物理机: 安装build-essential 练习1: 我注释掉了 #include <stdio.h> 出现下面错误 在你的文本编辑器中打开ex1文件,随机修改或删除一部分,之后…...
前端导出带有合并单元格的列表
// 导出async function exportExcel(fileName "共识调整.xlsx") {// 所有数据const exportData await getAllMainData();// 表头内容let fitstTitleList [];const secondTitleList [];allColumns.value.forEach(column > {if (!column.children) {fitstTitleL…...
MMaDA: Multimodal Large Diffusion Language Models
CODE : https://github.com/Gen-Verse/MMaDA Abstract 我们介绍了一种新型的多模态扩散基础模型MMaDA,它被设计用于在文本推理、多模态理解和文本到图像生成等不同领域实现卓越的性能。该方法的特点是三个关键创新:(i) MMaDA采用统一的扩散架构…...
论文笔记——相干体技术在裂缝预测中的应用研究
目录 相关地震知识补充地震数据的认识地震几何属性 相干体算法定义基本原理第一代相干体技术:基于互相关的相干体技术(Correlation)第二代相干体技术:基于相似的相干体技术(Semblance)基于多道相似的相干体…...
iOS性能调优实战:借助克魔(KeyMob)与常用工具深度洞察App瓶颈
在日常iOS开发过程中,性能问题往往是最令人头疼的一类Bug。尤其是在App上线前的压测阶段或是处理用户反馈的高发期,开发者往往需要面对卡顿、崩溃、能耗异常、日志混乱等一系列问题。这些问题表面上看似偶发,但背后往往隐藏着系统资源调度不当…...
MySQL JOIN 表过多的优化思路
当 MySQL 查询涉及大量表 JOIN 时,性能会显著下降。以下是优化思路和简易实现方法: 一、核心优化思路 减少 JOIN 数量 数据冗余:添加必要的冗余字段(如订单表直接存储用户名)合并表:将频繁关联的小表合并成…...
