关闭

Android性能专项测试之battery-historian试用

标签: 工具
17006人阅读 评论(11) 收藏 举报
分类:

数据准备

battery-historian工具需要使用bugreport中的Battery History
数据,我们在开始的时候需要通过以下命令来打开电池数据的获取以及重置:

adb shell dumpsys batterystats --enable full-wake-history
shell dumpsys batterystats --reset

执行的效果如下:

这里写图片描述

上面的操作相当于初始化操作,现在做一些测试,手动或者跑一些自动化的case都行。经过一段时间后,我们运行下面两条命令来将bugreport的信息保存到txt文档中,然后将txt文档转化为html文件。

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

上面的historian.py脚本是python写的,所以需要python环境,然后从github上下载这个脚本。上面两条命令执行成功后,会在目录下发现两个文件
bugreport.txt和battery.html,这个时候我们用google浏览器打开html文件,可以看到如下信息:

这里写图片描述

各个参数的意义

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

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

DUMP OF SERVICE batterystats:

Battery History (2% used, 5980 used of 256KB, 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中找到相应的信息。
现在来分析各个指标代表的意义:

横坐标

这里写图片描述

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

这里写图片描述

纵坐标

纵坐标的数据就很麻烦了,数据量太多,一条一条来吧。

battery_level

电量,可以看出电量的变化。比如上图中的数据显示刚开始电量是100%,然后在第11秒-12秒中间的某个时刻降到了99%。

plugged

充电状态,这一栏显示是否进行了充电,以及充电的时间范围。例如上图反映了我们在第22s插入了数据线,然后一直持续了数据采集结束。

screen

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

top

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

wake_lock*

wake_lock 该属性是记录wake_lock模块的工作时间。是否有停止的时候等

running

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

wake_lock_in

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

data_conn

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

status

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

phone_signal_strength

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

health

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

plug

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

5
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

性能优化之电量优化2-使用Battery Historian生成电量消耗报告

1 数据准备1.1 先断开adb服务,然后开启adb服务(a)adb kill-server 这一步很重要,因为当我们开发时做电量记录时会打开很多可能造成冲突的东西。为了保险起见我们重启adb。adb...
  • chenliguan
  • chenliguan
  • 2016-12-04 15:48
  • 6136

Battery Historian2.0使用过程中遇到的一些问题

could not parse aggregated battery stats 之前有一篇文章Android5.0系统耗电分析中提到用Battery Historian来分析耗电问题,但是在最近几次...
  • lhd201006
  • lhd201006
  • 2017-01-09 11:39
  • 1857

初步体验Android L的battery historian

周末在家没事,
  • oujunli
  • oujunli
  • 2014-07-08 13:52
  • 17672

使用BatteryHistorian分析和优化应用电量

欢迎Follow我的GitHub, 关注我的CSDN. 在Android项目中, 较难监控应用的电量消耗, 但是用户却非常关心手机的待机时间. 过度耗电的应用, 会遭到用户无情的卸载, 不要存在侥幸心...
  • u012515223
  • u012515223
  • 2016-03-01 09:23
  • 7645

性能优化十四之电量分析工具Battery Historian使用

上篇博客中并没有讲解BatterHistory该如何使用,这篇博客就开始给大家进行介绍。 数据准备 battery-historian工具需要使用bugreport中的BatteryHistory 1...
  • hpc19950723
  • hpc19950723
  • 2017-01-12 20:20
  • 1797

Battery Historian工具

手机耗电与统计 耗电量计算: W(电功率)=UI*T 由于在一部机器中,电压值U是恒定不变的(一般如此),因此可以忽略掉参数U,用电流及时间即可表示电量,即: Q(电容量,单位: mAh)...
  • baidu_35822271
  • baidu_35822271
  • 2016-12-09 10:34
  • 818

Android电量测试工具battery-historian学习小记

1. 环境配置: 1.1. 下载Go安装文件pkg,并进行安装, 输入命令go version检测是否安装成功: 1.2 配置Go的环境变量: 终端执行命令sudo vim .zshrc,打开环境...
  • swordgirl2011
  • swordgirl2011
  • 2016-04-19 22:06
  • 5575

Android性能优化(九)之不可忽视的电量

1、 前言 移动互联网的大潮到来之后,我们都变身好男人:“用智能手机的男人都是好男人,因为晚上必须回家充电。”一句笑言,但也可以看得出来目前使用智能设备电量方面的问题。 而开发者在电量消耗方面也起...
  • idaretobe
  • idaretobe
  • 2017-07-25 20:48
  • 294

BatteryHistorian的使用

http://blog.csdn.net/gjy211/article/details/53265293
  • super_zou
  • super_zou
  • 2017-10-16 11:53
  • 120

Battery Historian 2.0 for windows环境搭建

简介Battery Historian 1.0 通过python脚本转换成html文件,命令如下:python historian.py -a bugreport.txt > battery.html...
  • qq744746842
  • qq744746842
  • 2016-01-25 19:38
  • 3945
    个人资料
    • 访问:1698986次
    • 积分:21732
    • 等级:
    • 排名:第392名
    • 原创:570篇
    • 转载:1篇
    • 译文:9篇
    • 评论:571条
    博客专栏