bootchart抓Android系统启动各阶段性能数据

最近在做Android系统启动优化,首要任务是找到启动过程中各阶段耗时点,进而有针对性地进行优化。主要用bootchart抓开机数据,本文主要记录下工具的使用方法。

1.抓开机数据

adb root adb shell 'touch /data/bootchart/enabled'

adb reboot

重启后,生成的文件位于机器的/data/bootchart下。

2.解析数据

2.1 安装解析工具

复制代码
sudo apt install python-is-python3  //如果已经安装了pyhton3,就不需要再次安装
cd ~/Documents   //任意一个文件夹都可以
git clone https://github.com/xrmx/bootchart.git
cd bootchart/pybootchartgui
mv main.py.in main.py

2.2 指定pybootchartgui.py的路径

到下载的bootchart代码目录里找到pybootchartgui.py,记下全路径, 在$ANDROID_BUILD_TOP/system/core/init/grab-bootchart.sh里指定pybootchartgui.py的全路径, 注意,python要用python3

2.3 解析数据

在android源码根目录执行如下命令即可

$ANDROID_BUILD_TOP/system/core/init/grab-bootchart.sh

解析后在当前目录生成一个bootchart.png 的文件,截取一部分如下:

3.恢复出厂怎么抓bootchart ?

恢复出厂时,想抓开机各阶段的数据该怎么抓。恢复出厂会把/data下的数据都清除掉,所有只有通过修改代码如下:

/system/core/init/bootchart.cpp

参考:https://source.android.com/docs/core/perf/boot-times#bootchart

相关推荐
艾iYYY7 小时前
string 类的模拟实现
android·服务器·c语言·c++·算法
xyzzklk8 小时前
解决Salesforce无法向外发送邮件
android·java·开发语言·网络·crm·salesforce·客户关系管理
修炼者9 小时前
Gradle三阶段
android
morchalen10 小时前
安卓framework学习6:Contacts 联系人 APP 日志
android
KANGBboy10 小时前
java知识四(面向对象编程)
android·java·开发语言
AD钙奶-lalala13 小时前
Android Studio新建项目默认不使用Compose模版
android·ide·android studio
故渊at15 小时前
第一板块:Android 系统基石与运行原理 | 第二篇:Android 编译、打包与安装机制
android·系统架构·apk·打包·application·dalvik·android编译
故渊at16 小时前
第一板块:Android 系统基石与运行原理 | 第三篇:ART 与 Dalvik 运行时环境原理
android·对象模型·内存布局·运行原理·art·dalvik
私人珍藏库17 小时前
【Android】Wallcraft 3.62.0-最强4 K壁纸软件-解锁高级版
android·智能手机·app·工具·软件·多功能
GesLuck18 小时前
Node-RED企业微信发送—群文件
android·java·企业微信