Android省電的秘密(2)之a(chǎn)db解讀JobScheduler

前言###

adb是查看系統(tǒng)狀態(tài)一個(gè)很好的工具瘤缩,本文使用adb來解讀JobScheduler的狀態(tài)疲牵。JobScheduler是google為了省電而設(shè)計(jì)的一種用于調(diào)度工作的機(jī)制秧了,為了查看JobScheduler的運(yùn)行效果,除了實(shí)際觀察運(yùn)行狀態(tài)外侈离,adb也是一種很不錯(cuò)的輔助調(diào)試工具蹄葱。

目錄###

一.系統(tǒng)服務(wù)JobSchedulerService
二.注冊的job記錄文件jobs.xml
三.job參數(shù)解釋

一.系統(tǒng)服務(wù)JobSchedulerService#####

服務(wù)在SystemServer中注冊,屬于系統(tǒng)服務(wù)
源碼路徑:/frameworks/base/services/java/com/android/server/SystemServer.java

mSystemServiceManager.startService(JobSchedulerService.class);

執(zhí)行 adb shell service list查看系統(tǒng)服務(wù)究西,在列出的所有系統(tǒng)服務(wù)中可以找到

jobscheduler: [android.app.job.IJobScheduler]
二.注冊的job記錄文件jobs.xml#####

源碼路徑:/frameworks/base/services/core/java/com/android/server/job/JobStore.java
系統(tǒng)中的job記錄在文件jobs.xml窗慎,完整路徑是/data/system/job/jobs.xml,查看該文件手機(jī)要先root

    private JobStore(Context context, File dataDir) {
        mContext = context;
        mDirtyOperations = 0;

        File systemDir = new File(dataDir, "system");
        File jobDir = new File(systemDir, "job");
        jobDir.mkdirs();
        mJobsFile = new AtomicFile(new File(jobDir, "jobs.xml"));

        mJobSet = new ArraySet<JobStatus>();

        readJobMapFromDisk(mJobSet);
    }

cat命令查看該文件卤材,文件記錄著系統(tǒng)中此刻所有被調(diào)度的job

root@Xiaomi:/data/system/job # cat jobs.xml
<?xml version='1.0' encoding='utf-8' standalone='yes' ?>
<job-info version="0">
    <job jobid="137303610" package="com.google.android.apps.maps" class="com.google.android.apps.gmm.offline.OfflineAutoUpdateJobService" uid="10099">
        <constraints connectivity="true" idle="true" charging="true" />
        <periodic period="86400000" delay="1485554596322" />
        <extras />
    </job>
    <job jobid="137303609" package="com.google.android.apps.maps" class="com.google.android.apps.gmm.offline.OfflineAutoUpdateJobService" uid="10099">
        <constraints connectivity="true" idle="true" charging="true" />
        <one-off delay="1485444550825" />
        <extras />
    </job>
    <job jobid="1" package="com.example.wfcvs" class="com.example.wfcvs.wenfengService" uid="10146">
        <constraints charging="true" />
        <one-off delay="1485348887275" />
        <extras />
    </job>
    <job jobid="20537" package="android" class="com.android.server.backup.KeyValueBackupJob" uid="1000">
        <constraints connectivity="true" charging="true" />
        <one-off deadline="1485591350955" delay="1485519812187" />
        <extras />
    </job>
    <job jobid="808" package="android" class="com.android.server.MountServiceIdler" uid="1000">
        <constraints idle="true" charging="true" />
        <one-off delay="1485417599095" />
        <extras />
    </job>
</job-info>
三.job參數(shù)解釋#####
參數(shù) 解釋
jobid 每個(gè)job的id遮斥,android.app.job.JobInfo.Builder.Builder(int jobId, ComponentName jobService) 指定
package 包名
class job的類名,這個(gè)類繼承于JobService
uid 應(yīng)用uid
constraints job被調(diào)度的條件
one-off 跟時(shí)間相關(guān)扇丛,記錄job的deadline术吗,和延時(shí)執(zhí)行的時(shí)間,注意這個(gè)是時(shí)間點(diǎn)帆精,由函數(shù)systemclock.elapsedrealtime()生成较屿,即系統(tǒng)啟動(dòng)的時(shí)間材蹬,到這個(gè)時(shí)間點(diǎn)job會(huì)被觸發(fā)

例如:
<constraints connectivity="true" charging="true" /> 代表網(wǎng)絡(luò)連接并且在充電狀態(tài)下,job會(huì)被調(diào)度
<one-off delay="1485348887275" /> 代表job在滿足條件的情況下吝镣,必須要等到1485348887275這個(gè)時(shí)間點(diǎn)才會(huì)被執(zhí)行

jobs.xml文件需要手機(jī)root情況下才能查看堤器,沒有root要怎么查看呢?當(dāng)然有方法末贾,執(zhí)行adb shell dumpsys jobscheduler

 adb shell dumpsys jobscheduler
Started users: u0
Registered jobs:
  117..:[ComponentInfo{com.google.android.apps.maps/com.google.android.apps.gmm.offline.OfflineAutoUpdateJobService},jId=137303610,u0,R=(-172:44:27,none),N=1,C=true,I=true,F=1,P=true,ANI=true]
  148..:[ComponentInfo{com.google.android.apps.maps/com.google.android.apps.gmm.offline.OfflineAutoUpdateJobService},jId=137303609,u0,R=(-203:18:32,none),N=1,C=true,I=true,F=1,P=true,ANI=true]
  849..:[ComponentInfo{com.example.wfcvs/com.example.wfcvs.wenfengService},jId=1,u0,R=(56:07,none),N=0,C=true,I=false,F=8,P=true,ANI=true]
  246..:[ComponentInfo{android/com.android.server.MountServiceIdler},jId=808,u0,R=(-210:47:44,none),N=0,C=true,I=true,F=0,P=false,ANI=true]

Conn.
connected: true unmetered: true
148..: C=true, UM=false
117..: C=true, UM=false

Alarms (843148174)
Next delay alarm in 3367s
Next deadline alarm in 9223372036011627s
Tracking:
849..: (846515518, N/A)

Idle: false
3
  246..
  148..
  117..

Batt.
Stable power: true
246885848,14863036,11761044,84957259

AppIdle
Parole On: false
android:idle=false, com.google.android.apps.maps:idle=false, com.google.android.apps.maps:idle=false, com.example.wfcvs:idle=false,

Pending:

Active jobs:

mReadyToRock=true
mDeviceIdleMode=false

例如

849..:[ComponentInfo{com.example.wfcvs/com.example.wfcvs.wenfengService},jId=1,u0,R=(56:07,none),N=0,C=true,I=false,F=8,P=true,ANI=true]

849 代表這個(gè)job的hashcode的前三位
R 代表延時(shí)時(shí)間和deadline闸溃,(56:07,none)代表延時(shí)到56:07才能執(zhí)行,deadline為none代表沒有deadline拱撵。
N 代表網(wǎng)絡(luò)
C 代表充電
I 代表idle
F 代表調(diào)度失敗的次數(shù)
P 代表job是否Persist

好了辉川,伙伴們,使用你們的adb工具感受下吧拴测!新年快樂E移臁!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末集索,一起剝皮案震驚了整個(gè)濱河市屿愚,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌务荆,老刑警劉巖妆距,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異函匕,居然都是意外死亡娱据,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進(jìn)店門盅惜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來中剩,“玉大人,你說我怎么就攤上這事抒寂〗崽洌” “怎么了?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵蓬推,是天一觀的道長妆棒。 經(jīng)常有香客問我澡腾,道長沸伏,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任动分,我火速辦了婚禮毅糟,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘澜公。我一直安慰自己姆另,他們只是感情好喇肋,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著迹辐,像睡著了一般蝶防。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上明吩,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天间学,我揣著相機(jī)與錄音,去河邊找鬼印荔。 笑死低葫,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的仍律。 我是一名探鬼主播嘿悬,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼水泉!你這毒婦竟也來了善涨?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤草则,失蹤者是張志新(化名)和其女友劉穎躯概,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體畔师,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡娶靡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了看锉。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片姿锭。...
    茶點(diǎn)故事閱讀 39,690評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖伯铣,靈堂內(nèi)的尸體忽然破棺而出呻此,到底是詐尸還是另有隱情,我是刑警寧澤腔寡,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布焚鲜,位于F島的核電站,受9級特大地震影響放前,放射性物質(zhì)發(fā)生泄漏忿磅。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一凭语、第九天 我趴在偏房一處隱蔽的房頂上張望葱她。 院中可真熱鬧,春花似錦似扔、人聲如沸吨些。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽豪墅。三九已至泉手,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間偶器,已是汗流浹背螃诅。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留状囱,地道東北人术裸。 一個(gè)月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像亭枷,于是被迫代替她去往敵國和親袭艺。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評論 2 353

推薦閱讀更多精彩內(nèi)容