Systrace工具的使用

Systrace工具的使用

翻译原文地址:https://developer.android.com/studio/profile/systrace-commandline.html#requirements

通过抓取和展示app的执行次数,Systrace工具可以通帮助你分析app的性能问题,Systrace工具将android kernel层的数据比如CPU调度、disk activity以及应用线程收集起来,并生成HTML报告,在这个HTML报告里,可以看到指定时间内系统进程的所有情况。

systrace工具对于诊断应用的不流畅的问题非常有效,可以参照https://developer.android.com/studio/profile/systrace.html

要求

  • SDK 版本20及以上
  • python环境
  • android4.1及以上设备(需打开调试模式)
  • 可以通过用户界面去调用,也可以通过cmd的方式去调用

用户界面调用

  1. 打开Android studio,Tools -- Android -- Android Device Monitor,或则直接在sdk中的tools中找到Android Device Monitor打开
  2. 在弹出的Android Device Monitor中,左侧Devices选项卡的下面一排,点击下图中圈出的位置
Android Device Monitor
  1. 配置trace信息,点击OK后,会在对应目录下生成html文件
5.PNG

CMD命令调用

CMD的在androi4.2及以下、android4.3级以上的用法是不一样的,用法如下“

$ python systrace.py [options] [category1] [category2] ... [categoryN]

android4.3及以上

在这个版本上,你可以不配置分类tag,也可以自定义。使用方式如下:

$ cd android-sdk/platform-tools/systrace
$ python systrace.py --time=10 -o mynewtrace.html sched gfx view wm

提示:如果你想要查看task name,必须配置sched

命令行列表

选项 描述
-h 或 --help 查看帮助
-o <FILE> 用于指定html文件的存放路径
-t N 或 --time=N 用于指定抓取的时长,N为时长,单位为s,默认为5s,如果要指定10s,则”-t 10“
-b N或--buf-size=N 用于指定缓存大小,N为大小
-k <KFUNCS> 或 --ktrace=<KFUNCS> 指定activity的kernel方法,按逗号分割
-l 或 --list-categories 列出可选的分类,不通的设备分类可能不同
-a <APP_NAME> 或 --app=<APP_NAME> 开启app的trace,进程名按逗号分割,这些app必须有trace类的调用
--from-file=<FROM_FILE> 根据指定的文件创建html,而不是实时的trace,<FROM_FILE>为源文件路径
-e <DEVICE_SERIAL> 或 --serial=<DEVICE_SERIAL> 指定设备的序列号

android4.2及以下

在4.2之前的版本需要两部操作,首先,需要配置想要抓取的trace tag,然后再运行trace。比如:

$ cd android-sdk/platform-tools/systrace
$ python systrace.py --set-tags gfx,view,wm
$ adb shell stop
$ adb shell start
$ python systrace.py --disk --time=10 -o mynewtrace.html

命令行列表

选项 描述
-h 或 --help 查看帮助
-o <FILE> 用于指定html文件的存放路径
-t N 或 --time=N 用于指定抓取的时长,N为时长,单位为s,默认为5s,如果要指定10s,则”-t 10“
-b N或--buf-size=N 用于指定缓存大小,N为大小
-d 或 --disk 追踪activity disk的输入和输出,需要root设备
-i 或 --cpu-idle 追踪CPU的idel事件
-l 或 --cpu-load 追踪CPU的加载
-s或--no-cpu-sched 防止CPU调度的追踪,通过降低trace buffer的速率达到加长的trace时长的目的
-u 或 --bus-utilization 追踪bus的使用,需要root设备
-w 或 --workqueue 追踪work queue,需要root设备
--set-tags=<TAGS> 用于配置tag选项,

对于上面的--set-tags配置,可选项如下:

  • gfx 图形图像
  • input 输入
  • view 视图
  • webview
  • wm Window Manager
  • am Activity Manager
  • sync Synchronization Manager
  • audio
  • video
  • camera

注意:设置tag后,需要重启framework(’adb shell stop;adb shell start‘)暴躁配置生效。

如何查看trace.html文件

按键 作用
w 放大时间轴
s 缩小时间轴
a 向左移动面板
d 向右移动面板
e 以当前鼠标的位置为时间轴的中心
g 在选中的task开始时刻显示红线条
Shift+g 在选中的task结束时刻显示红线条
向右箭头 选中当前时间轴下一个事件
向左箭头 选中当前时间轴下一个事件
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,816评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,729评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,300评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,780评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,890评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,084评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,151评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,912评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,355评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,666评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,809评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,504评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,150评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,121评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,628评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,724评论 2 351

推荐阅读更多精彩内容