简介

Systrace 是 Android4.1 中新增的性能数据采样和分析工具。它可帮助开发者收集 Android 关键子系统(如 SurfaceFlinger/SystemServer/Kernel/Input/Display 等 Framework 部分关键模块、服务,View系统等)的运行信息,从而帮助开发者更直观的分析系统瓶颈,改进性能。

Systrace 的功能包括跟踪系统的 I/O 操作、内核工作队列、CPU 负载以及 Android 各个子系统的运行状况等。在 Android 平台中,它主要由3部分组成:

  • 内核部分:Systrace 利用了 Linux Kernel 中的 ftrace 功能。所以,如果要使用 Systrace 的话,必须开启 kernel 中和 ftrace 相关的模块。
  • 数据采集部分:Android 定义了一个 Trace 类。应用程序可利用该类把统计信息输出给ftrace。同时,Android 还有一个 atrace 程序,它可以从 ftrace 中读取统计信息然后交给数据分析工具来处理。
  • 数据分析工具:Android 提供一个 systrace.py( python 脚本文件,位于 Android SDK目录/platform-tools/systrace 中,其内部将调用 atrace 程序)用来配置数据采集的方式(如采集数据的标签、输出文件名等)和收集 ftrace 统计数据并生成一个结果网页文件供用户查看。 从本质上说,Systrace 是对 Linux Kernel中 ftrace 的封装。应用进程需要利用 Android 提供的 Trace 类来使用 Systrace.
    关于 Systrace 的官方介绍和使用可以看这里:Systrace

Systrace简单使用

  • Eclipse或Studio,手机准备好你要进行抓取的界面
  • 点击开始抓取(命令行的话就是开始执行命令)
  • 手机上开始操作
  • 设定好的时间到了之后,会将生成 Trace.html 文件,使用 Chrome 将这个文件打开进行分析

Systrace 文件如下

使用命令行工具抓取 Systrace

Systrace 工具在 Android-SDK 目录下的 platform-tools 里面,下面是简单的使用方法

1
2
$ cd android-sdk/platform-tools/systrace
$ python systrace.py

可以在 Bash 中配置好对应的路径和 Alias,使用起来还是很快速的。另外 User 版本所抓的 Systrce 文件所包含的信息,是比 eng 版本或者 Userdebug 版本要少的,建议使用 Userdebug 版本的机器来进行 debug,这样既保证了性能,又能有比较详细的输出结果.

抓取结束后,会生成对应的 Trace.html 文件,注意这个文件只能被 Chrome 打开。关于如何分析 Trace 文件,我们下面的章节会讲。不论使用那种工具,在抓取之前都可以选择参数,下面说一下这些参数的意思:

  • -h, –help Show the help message.(帮助)

  • -o Write the HTML trace report to the specified file.(即输出文件名,)

  • -t N, –time=N Trace activity for N seconds. The default value is 5 seconds. (Trace抓取的时间,一般是 : -t 8)

  • -b N, –buf-size=N Use a trace buffer size of N kilobytes. This option lets you limit the total size of the data collected during a trace.

  • -k

  • —ktrace= Trace the activity of specific kernel functions, specified in a comma-separated list.

  • -l, –list-categories List the available tracing category tags. The available tags are(下面的参数不用翻译了估计大家也看得懂,贴官方的解释也会比较权威,后面分析的时候我们会看到这些参数的作业的):

    • gfx - Graphics
    • input - Input
    • view - View
    • webview - WebView
    • wm - Window Manager
    • am - Activity Manager
    • audio - Audio
    • video - Video
    • camera - Camera
    • hal - Hardware Modules
    • res - Resource Loading
    • dalvik - Dalvik VM
    • rs - RenderScript
    • sched - CPU Scheduling
    • freq - CPU Frequency
    • membus - Memory Bus Utilization
    • idle - CPU Idle
    • disk - Disk input and output
    • load - CPU Load
    • sync - Synchronization Manager
    • workq - Kernel Workqueues Note: Some trace categories are not supported on all devices. Tip: If you want to see the names of tasks in the trace output, you must include the sched category in your command parameters.
  • -a

  • —app= Enable tracing for applications, specified as a comma-separated list of package names. The apps must contain tracing instrumentation calls from the Trace class. For more information, see Analyzing Display and Performance.

  • —link-assets Link to the original CSS or JavaScript resources instead of embedding them in the HTML trace report.

  • —from-file= Create the interactive Systrace report from a file, instead of running a live trace.

  • —asset-dir= Specify a directory for the trace report assets. This option is useful for maintaining a single set of assets for multiple Systrace reports.

  • -e

  • —serial= Conduct the trace on a specific connected device, identified by its device serial number.
    上面的参数虽然比较多,但使用工具的时候不需考虑这么多,在对应的项目前打钩即可,命令行的时候才会去手动加参数:

我们一般会把这个命令配置成Alias,配置如下:

1
2
alias st-start='python /sdk/platform-tools/systrace/systrace.py'
alias st-start-gfx-trace = ‘st-start -t 8 gfx input view sched freq wm am hwui workq res dalvik sync disk load perf hal rs idle mmc’

这样在使用的时候,可以直接敲 st-start 即可,当然为了区分和保持各个文件,还需要加上 -o xxx.html .上面的命令和参数不必一次就理解,只需要记住如何简单使用即可,在分析的过程中,这些东西都会慢慢熟悉的。

一般来说比较常用的是

  1. -o : 指示输出文件的路径和名字
  2. -t : 抓取时间(最新版本可以不用指定, 按 Enter 即可结束)
  3. -b : 指定 buffer 大小 (一般情况下,默认的 Buffer 是够用的,如果你要抓很长的 Trae , 那么建议调大 Buffer )
  4. -a : 指定 app 包名 (如果要 Debug 自定义的 Trace 点, 记得要加这个)

查看支持的 TAG

Systrace 默认支持的 TAG,可以通过下面的命令来进行抓取,不同厂商的机器可能有不同的配置,在使用的时候可以根据自己的需求来进行选择和配置,TAG 选的少的话,Trace 文件的体积也会相应的变小,但是抓取的内容也会相应变少。Trace 文件大小会影响其在 Chrome 中打开后的操作性能,所以这个需要自己取舍

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
$ adb shell atrace --list_categoriesgfx - Graphicsinput - Inputview - View Systemwebview - WebViewwm - Window Manageram - Activity Managersm - Sync Manageraudio - Audiovideo - Videocamera - Camerahal - Hardware Modulesres - Resource Loadingdalvik - Dalvik VMrs - RenderScriptbionic - Bionic C Librarypower - Power Managementpm - Package Managerss - System Serverdatabase - Databasenetwork - Networkadb - ADBvibrator - Vibratoraidl - AIDL callsnnapi - NNAPIrro - Runtime Resource Overlaycore_services - Core servicespdx - PDX servicessched - CPU Schedulingfreq - CPU Frequencyidle - CPU Idledisk - Disk I/Osync - Synchronizationmemreclaim - Kernel Memory Reclaimbinder_driver - Binder Kernel driverbinder_lock - Binder global lock tracememory - Memoryfreq - CPU Frequency and System Clock (HAL)gfx - Graphics (HAL)ion - ION Allocation (HAL)sched - CPU Scheduling and Trustzone (HAL)

添加Trace埋点

自定义Trace TAG

使用Trace.beginSection()Trace.endSection() 定义代码段

    @Overrideprotected void onCreate(Bundle savedInstanceState) {Trace.beginSection("MainActivity.onCreate");super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);mRecyclerView = findViewById(R.id.rv_main);Trace.beginSection("MainActivity.initData");initData();Trace.endSection();mRecyclerView.setLayoutManager(new LinearLayoutManager(this));mRecyclerView.addItemDecoration(new DividerItemDecoration(this,DividerItemDecoration.VERTICAL));mAdapter = new MyAdapter(this, mData);mRecyclerView.setAdapter(mAdapter);Trace.endSection();}

其中Trace.endSection(); 与最近的Trace.beginSection("SelfTag"); 配对结束。

使用命令

systrace.py 脚本中 -a 参数写自己的进程名字
python systrace.py -a com.xxx.xxx

Android Performance之工具篇(1)-systrace相关推荐

  1. Android卡顿掉帧问题分析之工具篇

    Android卡顿掉帧问题分析之原理篇 Android卡顿掉帧问题分析之工具篇 Android卡顿掉帧问题分析之实战篇 Android卡顿掉帧问题分析之原理篇 公众号:Android技术之家Andro ...

  2. android 测试工具,Android开源项目第四篇:开发及测试工具篇

    本文为那些不错的Android开源项目第四篇--开发工具篇,**主要介绍Android开发工具和测试工具相关的开源项目**. Android开源项目系列汇总已完成,包括: 1.Buck faceboo ...

  3. Android开源项目第二篇——工具库篇

    本文为那些不错的Android开源项目第二篇--开发工具库篇,主要介绍经常使用的开发库,包含依赖注入框架.图片缓存.网络相关.数据库ORM建模.Android公共库.Android 高版本号向低版本号 ...

  4. Android Studio Lint 工具看完这一篇还不够

    前言 以前对下面的问题,我的态度是,不报错就是没问题,报错就用快捷键,根据Android Studio提示修复问题,从来不去问个为什么?现在代码洁癖症越来越严重的我,忍不住想看清什么东西在搞鬼. 认真 ...

  5. Android学习路线_工具篇(一)简单的编辑器

    工欲善其事,必先利其器.工具,是人类进化的一大助力,善于制造与使用工具,可以加快我们学习的速度.工具在人类的进化之路上随着人类共同进化,原始的人类需要的是原始的工具,先进的工具对于原始人来说也许是个占 ...

  6. 学习Android从0开始之开发工具篇-Android studio详解

    版权声明:本文为博主原创文章,未经博主允许不得转载. Android studio详解 我们古人又云:工欲善其事,必先利其器. 1.android studio的背景 Android Studio 是 ...

  7. Android 手机自动化测试工具有哪几种?

    Android 手机自动化测试工具有哪几种? 3 条评论 分享 按投票排序按时间排序 28 个回答 78赞同 反对,不会显示你的姓名 知乎用户,https://github.com/truebit 孙 ...

  8. Android性能优化系列篇(三):崩溃优化+卡顿优化

    前言 汇总了一下众多大佬的性能优化文章,知识点,主要包含: UI优化/启动优化/崩溃优化/卡顿优化/安全性优化/弱网优化/APP深度优化等等等~ 本篇是第三篇:崩溃优化+卡顿优化 [非商业用途,如有侵 ...

  9. MTK Android software Tools工具的说明

    MTK发布的Android software Tools工具包,里面包含了很多的MTK工具,如下是简要说明及学习文档 MTK Android software Tools工具的说明如下: 工具 说明 ...

  10. Android专项测试性能篇整理

    Android专项测试性能篇整理 转自 slq520 分类专栏: APP性能测试 版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明. 本文链接:h ...

最新文章

  1. 网页解析:如何获得网页源码中嵌套的标签。
  2. 链表问题7——判断一个链表是否为回文结构(进阶)
  3. 西安java招聘_西安招聘 | 陕西安控科技公司招聘(员工宿舍、节日福利、餐补)...
  4. 挤牙膏只服英特尔!新酷睿14nm+++,性能竟超过AMD 7nm?
  5. 适合入门代码审计之熊海cms
  6. (仿头条APP项目)7.首页标签页完善和微头条页面设计实现
  7. 学习Bootstrap知识记录点-----导航菜单操作
  8. C#编程-Access数据库的简单应用
  9. c#语言float转换int,C#Float表达式:将结果float转换为int时的奇怪行为
  10. Java作业-数据库
  11. oracle rac 创建ocr,转:Oracle RAC 添加和删除OCR(10g)
  12. 1.OAuth 简介
  13. Scratch之小猫酷跑我设计
  14. java 加密方式_Get史上最优雅的加密方式!没有之一!
  15. 算法基础--梯度消失的原因
  16. 2020美亚杯个人赛
  17. 关于Twitter Card的一个巨坑
  18. web实例之电子日历
  19. 知识产权保护怎么申请以及怎样保护
  20. 考研邱关源电路总结第一章

热门文章

  1. 微信小程序利用腾讯云IM即时通讯发送文字+表情开发
  2. 软件测试人员必备的7种思维方式
  3. FFmpeg 软编码H.264与H.265
  4. 计算机无法对光盘格式化,使用驱动器X:中的光盘之前需要将其格式化,是否需要将其格式化?...
  5. 基于PHP使用thinkphp开发的教学管理系统
  6. go语言爬虫 - TapTap用户都喜欢些什么游戏
  7. 开源网站GitHub把自己给开源了
  8. 【金融手册】什么是本票、汇票、支票、银行承兑汇票、系统性、非系统性风险、巴塞尔协议、QDII...
  9. 基础回顾:10W+ 字 C 语言入门教程(上)
  10. 【024】基于51单片机的电子琴加音乐播放器系统Proteus仿真设计