電量優化(1)----工具安裝使用

電量優化的工具battery-historien

battery-historien工具是google開源的工具,一般的APP對電量優化不怎么關心。但是在大廠對電量優化是比較在乎的。應用測試工程師也應該對此工具需要一定的認識。

搭建流程在官網中有描述,https://github.com/google/battery-historian
官網中有兩種方法:

  • 1.使用Docker進行搭建。
    Docker是一種容器,一般用于云計算和大數據平臺。提倡的一種思想就是:軟 件即服務。這句話不是蓋的,一句話就可以將別人發布的docker服務環境一次全 部copy過來(注意是整個軟件環境哦,相當于復制了一臺一模一樣的主機,連軟件 都不要安裝了,全有了。彪悍吧!)
    但是Docker需要在window10上安裝才方便,如果不是window10就比較麻煩。還有是就是下載的安裝鏡像需要翻墻。
  • 2.自己編譯代碼,需要安裝比較多的軟件。

環境搭建步驟

使用第二種方法搭建

  1. 下載go,版本必須在1.8.1以上。官網翻墻才能訪問。給一個下載地址
    環境變量配置:
Paste_Image.png

其中GOPATH是后續下載源碼的工作目錄.
還必須把GOROOT放到 系統的path 中去 %GOROOT%/bin
成功后運行

Paste_Image.png

2.下載安裝python,需要是2.7不是3。下載地址https://www.python.org/downloads/release/python-2713/
需要配置環境變量,把python安裝的地址配置到path中去。
成功運行

Paste_Image.png

3.下載git安裝 https://www.git-scm.com/downloads
用于下載源碼。安裝并配置環境。
4.下載java配置環境變量。
注:3和4 應該對應程序猿應該電腦中都安裝了吧
5.下載源碼
運行 git bash 下載源碼

    go get -d -u github.com/google/battery-historian/…
Paste_Image.png

6.編譯源碼
進入到源碼目錄


Paste_Image.png

運行 go run setup.go

Paste_Image.png

注:這個地方需要等待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

Paste_Image.png

7.檢查/battery-historian是否運行,登錄網址 http://localhost:9999查看

Paste_Image.png

數據準備

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
Paste_Image.png

上面的操作為了多少清除一下不必要的數據。
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目錄下面,需要下載到命令行所在的目錄

Paste_Image.png

也就是在你下載的源碼的scripts路徑下。

上面兩條命令執行成功后,會在目錄下發現兩個文件
bugreport.txt和battery.html,這個時候我們用google瀏覽器打開html文件。但是需==要翻墻==

Paste_Image.png

各個參數的意義

橫坐標

Paste_Image.png

上面的10,20代表的就是秒的意思,它是以一分鐘為周期,到第60秒的時候變為0。橫坐標就是一個時間范圍,咱們的例子中統計的數據是以重置為起點,獲取bugreport內容時刻為終點。我們一共采集了多長時間的數據,圖表下也有信息說明。(經其他人的反饋,這個坐標間隔是會隨著時間的長度發生改變,所以要以你的實際情況為準。這個縮放級別可以調整的,如下圖:)

Paste_Image.png

縱坐標

  • 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多久。
    電池容量不會顯示單一行為消耗的具體電量,這里只能顯示使用電池的頻率和時長,你可以看分時段的剩余電量來了解具體消耗了多少電量。
Paste_Image.png
  • Job
    后臺的工作,比如服務service的運行
Paste_Image.png
  • 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 中上傳文件生成報告。

Paste_Image.png

分析的結果為:
Paste_Image.png

坑:必須翻墻才能得到數據

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 一、了解電量消耗 在電子編程世界,這種硬件消耗電量 來執行任務的過程,叫做超時電流消耗。耗電情況,例如:打開屏幕,...
    Ayres閱讀 1,212評論 0 1
  • 一、電量消耗理論與分析 寫出耗電量低的應用的關鍵是要透徹理解它的理論以及全部過程。下面將對電量消耗的相關理論知識進...
    香沙小熊閱讀 4,674評論 4 4
  • 硬件消耗電量 來執行任務的過程,叫做超時電流消耗主要消耗:1.最大的耗電是我們的屏幕2.蜂窩式無線數據交換(3G4...
    王者夢回Arvin閱讀 980評論 0 0
  • 清風吹拂著垂下的發絲,我一張張翻看著相冊里的照片,看見老屋時,很想再把歲月走一遍。在這個有陽光,有秋風的午后,想念...
    木蘭溪閱讀 422評論 3 6
  • 囡囡四歲半。愛唱愛跳,愛玩愛笑,很有自己的想法,想法還很堅定。 她覺得媽媽是最聰明的媽媽,所以生出她這個最聰明的寶...
    初夏微涼ing閱讀 259評論 0 2