Firebase作业未保留

时间:2018-03-29 23:01:17

标签: android firebase android-jobscheduler firebase-job-dispatcher

自Android 8更改以来,我在设置定期作业时遇到了各种问题。我选择使用Firebase调度程序,因为Lifetime.FOREVER听起来很有希望。我的工作是下载一些JSON数据并定期存储,时间并不重要。这是我创建作业的代码:

dispatcher.newJobBuilder()
            .setService(MPWService.class)
            .setTag("mpw-updater")
            .setRecurring(true)
            .setLifetime(Lifetime.FOREVER)
            .setTrigger(periodicTrigger(intervalMsec, (intervalMsec/100)*10))
            .setReplaceCurrent(true)
            // retry with exponential backoff
            //.setRetryStrategy(RetryStrategy.DEFAULT_EXPONENTIAL)
            .setExtras(myExtrasBundle)
            .build();

几乎按预期工作,基于intervalMsec每30分钟左右安排一次。但是,当应用程序长时间不使用(并且无法再使用全局接收器重新安排作业)或设备重新启动时,该作业将不再安排。

用于调度作业的代码放在Activity的onCreate方法中:

    FirebaseJobDispatcher dispatcher = new FirebaseJobDispatcher(new GooglePlayDriver(this));
    Job myJob = MPWService.getJobUpdate(prefs, dispatcher);
    dispatcher.schedule(myJob);

我已尝试使用adb shell dumpsys activity service GcmService | grep mystuff调试我的服务,并提出了我的问题

   (scheduled) it.angelic.mpw/com.firebase.jobdispatcher.GooglePlayReceiver{u=0 tag="mpw-updater" 
           trigger=window{start=1620s,end=1800s,earliest=1612s,latest=1792s} requirements=[NET_ANY] attributes=[RECURRING] scheduled=-7s last_run=N/A jid=N/A status=PENDING retries=0 client_lib=FIREBASE_JOB_DISPATCHER-1}
   (finished) [it.angelic.mpw/com.firebase.jobdispatcher.GooglePlayReceiver:mpw-updater,u0]

我的问题:

  1. 为什么last_run = N / A?我很确定我总是通过jobFinished()电话来结束服务执行。
  2. 为什么我的工作属性被标记为[RECURRING]而不是我所期望的[PERSISTED,RECURRING]?
  3. earliest=1612s,latest=1792s的含义是什么?

1 个答案:

答案 0 :(得分:1)

很快,很快发现.setLifetime(Lifetime.FOREVER)需要:

<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>
清单中的

。请参阅问题1和3,谢谢