1

自 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();

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

用于调度作业的代码放置在 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
4

1 回答 1

1

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

<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>

在清单中。请看问题1和3,谢谢

于 2018-03-29T23:19:42.563 回答