电量优化的工具battery-historien
battery-historien工具是google开源的工具,一般的APP对电量优化不怎么关心。但是在大厂对电量优化是比较在乎的。应用测试工程师也应该对此工具需要一定的认识。
搭建流程在官网中有描述,https://github.com/google/battery-historian
官网中有两种方法:
- 1.使用Docker进行搭建。
Docker是一种容器,一般用于云计算和大数据平台。提倡的一种思想就是:软 件即服务。这句话不是盖的,一句话就可以将别人发布的docker服务环境一次全 部copy过来(注意是整个软件环境哦,相当于复制了一台一模一样的主机,连软件 都不要安装了,全有了。彪悍吧!)
但是Docker需要在window10上安装才方便,如果不是window10就比较麻烦。还有是就是下载的安装镜像需要翻墙。 - 2.自己编译代码,需要安装比较多的软件。
环境搭建步骤
使用第二种方法搭建
- 下载go,版本必须在1.8.1以上。官网翻墙才能访问。给一个下载地址。
环境变量配置:
其中GOPATH是后续下载源码的工作目录.
还必须把GOROOT放到 系统的path 中去 %GOROOT%/bin
成功后运行
2.下载安装python,需要是2.7不是3。下载地址https://www.python.org/downloads/release/python-2713/
需要配置环境变量,把python安装的地址配置到path中去。
成功运行
3.下载git安装 https://www.git-scm.com/downloads。
用于下载源码。安装并配置环境。
4.下载java配置环境变量。
注:3和4 应该对应程序猿应该电脑中都安装了吧
5.下载源码
运行 git bash 下载源码
go get -d -u github.com/google/battery-historian/…
6.编译源码
进入到源码目录
运行 go run setup.go
注:这个地方需要等待10来分钟下载第三方工具。也可以自行下载。
下载【closure-library】和【closure-compiler】和【flot-axislabels】,解压放到GOROOT目录下third_party文件夹下方的的closure-compiler和closure-library和flot-axislabels文件夹 ../battery-historian\third_party;如果没有均手动创建
6.运行监听
go run cmd/battery-historian/battery-historian.go
7.检查/battery-historian是否运行,登录网址 http://localhost:9999查看
数据准备
battery-historian工具需要使用bugreport中的Battery History
1.先断开adb服务,然后开启adb服务
adb kill-server 这一步很重要,因为当我们开发时做电量记录时会打开很多可能造成冲突的东西。为了保险起见我们重启adb。adb devices就会自动连接查找手机。当然也可以adb start-server
2.重置电池数据收集
数据,我们在开始的时候需要通过以下命令来打开电池数据的获取以及重置:
adb shell dumpsys batterystats --enable full-wake-history
adb shell dumpsys batterystats --reset
上面的操作为了多少清除一下不必要的数据。
3.从手机中导出数据
//For devices 6.0 and lower
adb bugreport > bugreport.txt
//Android 7.0 and higher
adb bugreport bugreport.zip
或者用下面的命令也可以:
adb shell dumpsys batterystats > batterystats.txt
adb shell dumpsys batterystats > com.example.android.sunshine.app > batterystats.txt
加上包名可以限制输出的数据是我们要检测的。但是这个txt的数据可读性不强.
后面这种方法生成的TXT文件是没法上传到battery-historian服务上面进行分析的,因为不兼容。
数据分析
1.historian-V1之前的版本分析方式
将txt文档转化为html文件,命令如下。
python historian.py -a bugreport.txt > battery.html
上面的historian.py脚本是Python写的,所以需要python环境,然后从github上下载这个脚本。文件在github上面的scripts目录下面,需要下载到命令行所在的目录
也就是在你下载的源码的scripts路径下。
上面两条命令执行成功后,会在目录下发现两个文件
bugreport.txt和battery.html,这个时候我们用google浏览器打开html文件。但是需==要翻墙==。
各个参数的意义
横坐标
上面的10,20代表的就是秒的意思,它是以一分钟为周期,到第60秒的时候变为0。横坐标就是一个时间范围,咱们的例子中统计的数据是以重置为起点,获取bugreport内容时刻为终点。我们一共采集了多长时间的数据,图表下也有信息说明。(经其他人的反馈,这个坐标间隔是会随着时间的长度发生改变,所以要以你的实际情况为准。这个缩放级别可以调整的,如下图:)
纵坐标
-
battery_level
电量,可以看出电量的变化。比如上图中的数据显示刚开始电量是100%,然后在第11秒-12秒中间的某个时刻降到了99%。
- plugged
充电状态,这一栏显示是否进行了充电,以及充电的时间范围 - 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
是否跟后台同步.
可以把鼠标停在某一项上面。可以看到何时sync同步 启动的,持续时间Duration多久。
电池容量不会显示单一行为消耗的具体电量,这里只能显示使用电池的频率和时长,你可以看分时段的剩余电量来了解具体消耗了多少电量。
- Job
后台的工作,比如服务service的运行
- data_conn
数据连接方式的改变,上面的edge是说明采用的gprs的方式连接网络的。此数据可以看出手机是使用2g,3g,4g还是wifi进行数据交换的。这一栏可以看出不同的连接方式对电量使用的影响。 - status
电池状态信息,有充电,放电,未充电,已充满,未知等不同状态。
这一栏记录了电池状态的改变信息。 - phone_signal_strength
手机信号状态的改变。
这一栏记录手机信号的强弱变化图,依次来判断手机信号对电量的影响。 - health
电池健康状态的信息,这个信息一定程度上反映了这块电池使用了多长时间。
这一栏记录电池状态在何时发生改变,上面的图中电池状态一直处于good状态。 - plug
充电方式,usb或者插座,以及显示连接的时间。
这一栏显示了不同的充电方式对电量使用的影响。
重要的参数:WiFi、wake_lock、conn、mobile_ratio(蜂窝信号)
2.historian-V2最新的版本的方式
将生成bugreport.txt文件在 http://localhost:9999 中上传文件生成报告。
分析的结果为:
坑:必须翻墙才能得到数据