電量優化的工具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%。
Paste_Image.png - 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 中上傳文件生成報告。
分析的結果為:
坑:必須翻墻才能得到數據