摘要:
由于原生Job机制会使用Doze的白名单,故遇到WAIT:DEV_NOT_DOZING现象,一般配置为Whitelist user apps名单即可解决问题
Doze名单类型 | 配置对象 | 配置方法 | 影响 |
Whitelist user apps | 第三方应用 | 1.Adb shell 命令:adb shell dumpsys deviceidle whitelist +com.test 2.DeviceIdleController接口:addPowerSaveWhitelistApp | 黑名单应用Doze期被限制job,窗口期放风 白名单机制Doze期和窗口期也可以触发job |
Whitelist system apps | 系统应用 | platform.xml配置 | 系统应用Doze期也会被限制job,窗口期放风 |
备注 | Forground进程属于PowerSaveTempWhitelist也会动态允许Doze期和窗口期触发job,故带消息通知的进程一般也可以自动豁免 |
备注:评估该业务是核心业务且满足功耗下,添加第三方应用为Doze的Whitelist user apps名单,即可以在Doze下也能触发job
Doze期被限制Job的现象
1 WAIT:DEV_NOT_DOZING 日志
日志关键字:WAIT:DEV_NOT_DOZING
从日志解读:该job在等待非doze或doze窗口期才能执行。 // 04-12 15:21:51.893 9066 9995 I JobScheduler.Time: Skipping JobStatus{b74bc94 #1000/20220929 com.xxx.logupload/.LogUploadService u=0 s=1000 TIME=+8m8s516ms:none WAIT:DEV_NOT_DOZING(等待非doze或doze窗口期) satisfied:0x9400000 unsatisfied:0x80000000} because delay won't make it ready.
2 WAIT:DEV_NOT_DOZING 解决方案
评估该业务是核心业务且满足功耗下,添加第三方应用为Doze的Whitelist user apps名单,即可以在Doze下也能触发job
3 Doze使用Whitelist user apps名单的相关源
android/qssi/frameworks/base/apex/jobscheduler/service/java/com/android/server/job/controllers/DeviceIdleJobsController.java
public DeviceIdleJobsController(JobSchedulerService service) {
super(service);
....
mDeviceIdleWhitelistAppIds = mLocalDeviceIdleController.getPowerSaveWhitelistUserAppIds();
mPowerSaveTempWhitelistAppIds =
mLocalDeviceIdleController.getPowerSaveTempWhitelistAppIds();
....
}