Systrace和RheaTrace使用

不管是应用开发,还是性能优化,都需要借助Systrace工具。

今天我们主要从Systrace工具入手,介绍一款字节开源的RheaTrace库(又名btrace,下文简称btrace)的使用。

Systrace

systrace是Google官方提供的,用于检测Android系统组件随时间运行状态的工具。

监控方法

Systrace的原理特别简单,就是在方法的开始和结束处,分别调用traceBegintraceEnd方法。

将运行的结果组成Trace Event格式,借助Google提供Trace Viewer解析工具,呈现出以时间为横轴的方法调用堆栈图。

Android源码里,可以看到很多相关的代码。

Java层代码:

import android.os.Trace;
Trace.traceBegin(long traceTag, String methodName)
Trace.traceEnd(long traceTag)

Native层代码:

#include<utils/Trace.h>
ATRACE_CALL();

我们也可以在应用代码中,手动调用Trace的方法增加对应用方法的监控。

import android.os.Trace;
Trace.beginSection(String sectionName)
Trace.EndSection()

抓trace

  1. 通过adb连接手机。

  2. 进入本地的systrace目录:/Users/${user_name}/Library/Android/sdk/platform-tools/systrace,执行如下命令:

python systrace.py -b 32768 -t 5 -o mytrace.html gfx input view webview wm am sm audio video camera hal app res dalvik rs bionic power sched irq freq idle disk mmc load sync workq memreclaim regulators

为了后续操作方便,可以将systrace的路径加入环境变量,也可以设置alias

systrace的缺点

默认只有Android系统的源码里添加了Trace相关的代码,应用代码如果想要加入监控,需要手动添加,效率太低。

btrace

btrace是字节开源的基于SystraceAndroid trace工具,可以在编译期间自动注入自定义事件。

下面介绍一下,如何使用btrace来对应用进行更完整的监控。

其实btrace的文档已经写得很清楚了,大家可以直接去看文档,我在这里也给大家简单列一下。

1. 编译前

要使用btrace的插桩能力,需要在app工程中进行一些修改。

操作非常简单,只需要引入plugin,进行相应的配置即可。

首先,在根目录的build.gradle中增加rhea-gradle-plugin依赖。

buildscript {
    repositories {
        ...
        mavenCentral()
        ...
    }
    dependencies {
        classpath 'com.bytedance.btrace:rhea-gradle-plugin:1.0.1'
    }
}

allprojects {
    repositories {
        ...
        mavenCentral()
        ...
    }
}

然后在app/build.gradle文件中增加对应的插件和依赖,进行一些自定义的配置。

dependencies {
    //rheatrace core lib
    implementation "com.bytedance.btrace:rhea-core:1.0.1"
}
...
rheaTrace {
   compilation {
      //为减少 APK 体积, 你可以为 App 中需要跟踪的方法设置 id 以此来跟踪此自定义事件, 默认值 false。
      traceWithMethodID = false 
      //该文件配置决定哪些方法您不希望跟踪, 默认值 null。
      traceFilterFilePath = "${project.rootDir}/rhea-trace/traceFilter.txt"
      //用特指定方法 id 来设置自定义事件名称, 默认值 null。
      applyMethodMappingFilePath = "${project.rootDir}/rhea-trace/keep-method-id.txt"
  }

   runtime {
      //仅在主线程抓取跟踪事件, 默认值 false。
      mainThreadOnly true 
      //在 App 启动之初开始抓取跟踪事件, 默认值 true。
      startWhenAppLaunch true
      //指定内存存储 atrace 数据 ring buffer 的大小。
      atraceBufferSize "500000"
   }
}
// 增加插件
apply plugin: 'com.bytedance.rhea-trace'

2. 配置脚本环境

1. 确认python版本

目前btrace只支持python2.7,所以在使用之前,先确认一下当前使用的python版本号。

python --version

2. 配置systrace环境变量

因为btrace需要依赖systrace,所以必须配置systrace的环境变量,让我们可以任何目录访问到systrace

export PATH=${PATH}:/Users/${user_name}/Library/Android/sdk/platform-tools/systrace

这里有一个问题,高版本的Android sdk移除了systrace,可以从30.0.0以下的版本下载systrace,拷贝到Android sdk目录下。

3. 抓trace

systrace差不多,也是将手机通过adb连接,执行一个python脚本。

进入目录btrace/scripts/python/rheatrace,执行如下命令。

python rheatrace.py -a rhea.sample.android -t 5 -o ./output/mynewtrace.html sched freq idle am wm gfx view binder_driver hal dalvik camera input res

各个参数的含义,可以查阅文章最后附带的btrace官方README,如果使用过systrace的同学应该对这里的参数很熟悉。

执行完脚本后,在手机上执行你要监控的操作,等时间到了会自动生成trace文件。

4. 通过文件修改配置

支持通过文件修改配置,是我觉得btrace做得特别好的地方。

大概是因为字节的app也都比较重,编译一次很耗时,所以才有了这个方案,正好击中了开发大型app的同学们的痛点。

方法是创建名字为rheatrace.configProperties格式文件,写入如下配置,再pushsdcard/rhea-trace/${应用包名}下,重启即可让配置生效。

io=true
classLoad=true
memory=true
mainThreadOnly=true
atraceBufferSize=100000
startWhenAppLaunch=true

具体的字段含义,可以到btrace的github README上找,链接贴在文章最后。

5. 用Perfetto打开

Perfetto是Google新开发的性能调试工作,比Trace ViewerUI更好看,操作更快更便捷,且支持protobuf编码格式。

Perfetto是兼容Trace Event格式的,所以systrace抓取到的文件可以直接用Perfetto打开。perfetto

参考文章

bytedance btrace github
trace-viewer格式
Perfetto Quickstart

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

推荐阅读更多精彩内容