第6讲 如何通过perfetto抓取trace - Android Camera性能分析

本讲是Android Camera性能分析专题的第6讲,我们介绍如何通过perfetto抓取trace,包括如下内容:

  1. 启动Tracing服务
  2. 通过命令行方式抓取perfetto trace
    1. 通过python脚本抓取perfetto trace
    2. 通过perfetto命令抓取perfetto trace
  3. 通过UI方式抓取perfetto trace

视频在线观看:

加入知识星球与更多Camera同学交流
– 星球名称:深入浅出Android Camera
– 星球ID: 17296815

启动Tracing服务

从Android P开始Android引入perfetto,在Android R才默认打开Tracing服务

打开方法

  • Android P和Android Q才需要手动先打开
# Needed only on Android 9 (P) and 10 (Q) on non-Pixel phones.
adb shell setprop persist.traced.enable 1
adb reboot

确认相关服务是否正常启动

HWPCT:/ $ ps -A |grep -iE "traced"
nobody        1016     1   46520   2444 0                   0 S traced
nobody        1017     1   46520   2624 0                   0 S traced_probes

通过命令行方式抓取perfetto trace

通过python脚本抓取perfetto trace

抓取perfetto的python脚本

执行抓取命令(与systrace类似)

python3 record_android_trace -o trace_file.perfetto-trace -t 10s -b 32mb -n sched freq idle am wm gfx view binder_driver hal dalvik camera input res memory

还可以指定configure文件

  • 如何产生perfetto configure文件

  • 命令

    python3 record_android_trace -o trace_file.perfetto-trace -t 10s -b 32mb -n -c record_camera.config

通过perfetto命令抓取perfetto trace

执行抓取命令

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

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

还可以指定Configure文件

adb push record_camera.config /data/local/tmp/record_camera.config

adb shell “cat /data/local/tmp/record_camera.config | perfetto --txt -c - -o /data/misc/perfetto-traces/trace.perfetto-trace”

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

通过UI方式抓取perfetto trace

在Settings中配置和打开trace

Developer options > System tracing
  • 选择Category

  • Show quick settings title

Pull 抓取到的trace

adb pull /data/local/traces
赞(10)
未经允许不得转载:极客笔记 » 第6讲 如何通过perfetto抓取trace

评论 2

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址
  1. #1

    如果抓不出来,看下/sys/kernel/debug/tracing/tracing_on的值是否为0 ,不为0的话,改成0再抓
    如果tracing_on为1, perfetto无法正常工作

    admin4个月前 (11-23)回复
  2. #2

    echo 0 > /sys/kernel/debug/tracing/tracing_on

    admin4个月前 (11-23)回复