android电量优化之Battery Historian工具使用

前几天写了关于androidAPP性能优化总结的文章,还没有看的话可以看一下,这文章提到了电量优化,android耗电分析所用到的工具battery-historian,这里做一个总结.

在 Android5.0 以前,在应用中测试电量消耗比较麻烦,也不准确,5.0 之后专门引入了一个获取设备上电量消耗信息的 API:Battery Historian。Battery Historian 是一款由 Google 提供的 Android 系统电量分析工具,是一款图形化数据分析工具,直观地展示出手机的电量消耗过程,通过输入电量分析文件,显示消耗情况,最后提供一些可供参考电量优化的方法。

数据准备

battery-historian工具需要使用bugreport中的Battery History

  • 1.先断开adb服务,然后开启adb服务
    adb kill-server 这一步很重要,因为当我们开发时做电量记录时会打开很多可能造成冲突的东西。为了保险起见我们重启adb。
    adb devices就会自动连接查找手机。当然也可以adb start-server

  • 2.重置电池数据收集数据,我们在开始的时候需要通过以下命令来打开电池数据的获取以及重置:

    adbshelldumpsysbatterystats--enable full-wake-history
    
    adbshelldumpsysbatterystats--reset
    

执行的效果如下:

image.png

上面的操作相当于初始化操作,如果不这么做会有一大堆的干扰的数据,看起来会比较痛苦。然后把数据线直接拔掉(防止数据线造成充放电数据干扰),现在做一些[测试],手动或者跑一些自动化的case都行。经过一段时间后,我们重新连接手机确认adb连上了,运行下面这条命令来将bugreport的信息保存到txt文档中,

adb bugreport> bugreport.txt

或者用下面的命令也可以:

adb shell dumpsysbatterystats> batterystats.txt
adb shell dumpsysbatterystats>com.example.android.sunshine.app> batterystats.txt

加上包名可以限制输出的数据是我们要检测的。
但是这个txt的数据可读性不强。接下来我们就要用到这个battery-historian工具了。

到此我们有两种方式分析这个文件:(historian-V1之前的版本和historian-V2最新的版本)

historian-V1之前的版本分析方式:

将txt文档转化为html文件,命令如下。

python historian.py -a bugreport.txt> battery.html

上面的historian.py脚本是Python写的,所以需要python环境,然后从github上下载这个脚本。文件在github上面的scripts目录下面,需要下载到命令行所在的目录

image.png

上面两条命令执行成功后,会在目录下发现两个文件
bugreport.txt和battery.html,这个时候我们用google浏览器打开html文件,可以看到如下信息:


image.png
各个参数的意义

首先我们在bugreport.txt找到Battery History数据栏类似下面的信息:

  -------------------------------------------------------------------------------

  DUMPOFSERVICEbatterystats:

  BatteryHistory (2% used, 5980 used of256KB, 45 strings using 2592):

  0 (9) RESET:TIME: 2015-03-05-15-21-56

  0 (2) 100 c0900422 status=discharging health=good plug=none temp=200       volt=4167 +running +wake_lock +sensor +screen data_conn=edge phone_signal_strength=great brightness=medium proc=u0a15:"android.process.acore"

  0 (2) 100 c0900422 proc=u0a7:"com.android.cellbroadcastreceiver"

  0 (2) 100 c0900422 proc=u0a53:"com.android.gallery3d"

你在html中信息都能从bugreport.txt中找到相应的信息。

现在来分析各个指标代表的意义:

  • 横坐标
    image.png

上面的10,20代表的就是秒的意思,它是以一分钟为周期,到第60秒的时候变为0。横坐标就是一个时间范围,咱们的例子中统计的数据是以重置为起点,获取bugreport内容时刻为终点。我们一共采集了多长时间的数据,图表下也有信息说明。(经其他人的反馈,这个坐标间隔是会随着时间的长度发生改变,所以要以你的实际情况为准。这个缩放级别可以调整的,如下图:)

image.png
  • battery_level
    电量,可以看出电量的变化。比如上图中的数据显示刚开始电量是100%,然后在第11秒-12秒中间的某个时刻降到了99%。
image.png
  • plugged
    充电状态,这一栏显示是否进行了充电,以及充电的时间范围。例如上图反映了我们在第22s插入了数据线,然后一直持续了数据采集结束。

  • screen
    屏幕是否点亮,这一点可以考虑到睡眠状态和点亮状态下电量的使用信息。

  • top
    该栏显示当前时刻哪个app处于最上层,就是当前手机运行的app,用来判断某个app对手机电量的影响,这样也能判断出该app的耗电量信息。该栏记录了应用在某一个时刻启动,以及运行的时间,这对我们比对不同应用对性能的影响有很大的帮助。

  • wake_lock
    wake_lock 该属性是记录wake_lock??榈墓ぷ魇奔?。是否有停止的时候等

  • running
    界面的状态,主要判断是否处于idle的状态。用来判断无操作状态下电量的消耗。

  • wake_lock_in
    wake_lock有不同的组件,这个地方记录在某一个时刻,有哪些部件开始工作,以及工作的时间。

  • gps
    gps是否开启

  • phone_in_call
    是否进行通话

  • Sync
    是否跟后台同步.
    可以把鼠标停在某一项上面??梢钥吹胶问眘ync同步启动的,持续时间Duration多久。电池容量不会显示单一行为消耗的具体电量,这里只能显示使用电池的频率和时长,你可以看分时段的剩余电量来了解具体消耗了多少电量。

    image.png

  • Job
    后台的工作,比如服务service的运行。从下面图中可以看到qihoo的AppStore和鲁大师都在运行后台服务。

    image.png

  • data_conn
    数据连接方式的改变,上面的edge是说明采用的gprs的方式连接网络的。此数据可以看出手机是使用2g,3g,4g还是wifi进行数据交换的。这一栏可以看出不同的连接方式对电量使用的影响。

  • status
    电池状态信息,有充电,放电,未充电,已充满,未知等不同状态。
    这一栏记录了电池状态的改变信息。

  • phone_signal_strength
    手机信号状态的改变。
    这一栏记录手机信号的强弱变化图,依次来判断手机信号对电量的影响。

  • health
    电池健康状态的信息,这个信息一定程度上反映了这块电池使用了多长时间。
    这一栏记录电池状态在何时发生改变,上面的图中电池状态一直处于good状态。

  • plug
    充电方式,usb或者插座,以及显示连接的时间。
    这一栏显示了不同的充电方式对电量使用的影响。

historian-V2最新的版本的方式:

将生成bugreport.txt文件在 [http://localhost:9999](javascript:goto();) 中上传文件生成报告(前提在本地或者某服务器上搭好了battery-historian项目环境

image.png

其实在这里也可以看到两种版本分析模式:

image.png

好了,battery-historian分析工具就写到这里,大家有兴趣的话可以去试试!

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

推荐阅读更多精彩内容