Android Perfetto 监控应用启动耗时

Perfetto 是一个 Google 开发的用于安卓系统性能监控和调试的工具,它旨在提供实时数据收集和可视化功能,帮助我们分析和优化应用程序的性能表现。Perfetto 可以捕获系统事件、CPU、内存、网络、GPU 等性能指标数据,并将其记录为轻量级的 Trace 文件,我们可以通过 Perfetto 的可视化界面(ui.perfetto.dev/)或者命令行工具进行查…

此前更多使用的是 Systrace,而 Perfetto 相比 Systrace 有更多的优势。

Perfetto 支持更多的性能指标数据的采集和记录,包括系统事件、内核跟踪、堆栈跟踪等,提供了更全面的性能分析功能。其次, Perfetto 的可视化界面也更加友好和直观,方便我们快速理解和分析数据。

在实际的开发过程中,做启动优化和监控单纯靠 Traceview 是不太准确的,因为 Traceview 获取的信息比较局限,而 Perfetto 能站在上帝视角来查看应用的启动过程。

接下来我举一个使用 Perfetto 的 ADB 命令来监控应用启动耗时的例子

在应用启动的时候故意写一个耗时(渲染一个布局800次):

1
2
3
4
5
6
7
8
9
js复制代码class MyApp : Application() {

override fun onCreate() {
super.onCreate()
for (i in 0 until 800) {
LayoutInflater.from(this).inflate(R.layout.activity_main, null)
}
}
}

把应用安装到手机上,杀掉要监控的应用的进程,回到桌面,准备工作就算完成了

1f6e85091e14452d84e4cfbac9b2ff2a.png
使用 adb 命令开启监控:

adb shell perfetto -o /data/misc/perfetto-traces/trace_file.perfetto-trace -t 5s sched freq idle am wm gfx view binder_driver hal dalvik res memory

一按回车会进入录制状态:

20e9d14aa23c4235b9611e9e15cbac93.png
在录制状态下打开应用,等待录制结束

34385c44084143eaa72cddd07f98576f.png

录制完成后再使用 adb 命令将 Trace 文件导到本地电脑上:

adb pull /data/misc/perfetto-traces/trace_file.perfetto-trace

将 Trace 文件拖入可视化界面(ui.perfetto.dev/ )它会自动打开

a0ce455349f849dc8e8341f2ca2d26b8.png

确认有 Android App Startups 标识(没有的话重新录制一遍)

展开要监控的包名就能看到启动信息了:

6f8199cd63094e82b98d25e224d05662.png

这个 bindApplication 就是 App 启动初始化的过程了,可见是非常长的,也就是比较耗时。我们将其放大即可看到具体的耗时操作(使用键盘上的 ws 可以缩放,ad 可以左右移动)

45332adfe1274cc3ba9f5f09b5078e84.png

可见上面密密麻麻的 inflate,因为我们在 Application 的 onCreate 中渲染了 800 次布局

我们知道了做了哪些耗时操作后,再根据业务实际情况进行异步等优化处理,这样子我们启动优化的目的就达到了

本文转载自: 掘金

开发者博客 – 和开发相关的 这里全都有

0%