自 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]
我的问题:
- 为什么 last_run=N/A ?我很确定我总是通过
jobFinished()
调用来结束服务执行。 为什么我的工作属性被标记为 [RECURRING] 而不是我所期望的 [PERSISTED,RECURRING]?- 是什么意思
earliest=1612s,latest=1792s
?