App使用Job中遇到的WAIT DEV_NOT_DOZING的解决方案

摘要:

由于原生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();
        ....
        
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

法迪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值