JobScheduler内幕实现和深度思考(第七篇)

接着上一节我们看到了JobGenerator.generateJobs()方法:

private def generateJobs(time: Time) {
    // Set the SparkEnv in this thread, so that job generation code can access the environment
    // Example: BlockRDDs are created in this thread, and it needs to access BlockManager
    // Update: This is probably redundant after threadlocal stuff in SparkEnv has been removed.
    SparkEnv.set(ssc.env)
    Try {
      jobScheduler.receiverTracker.allocateBlocksToBatch(time) // allocate received blocks to batch
      graph.generateJobs(time) // generate jobs using allocated block
    } match {
      case Success(jobs) =>
        val streamIdToInputInfos = jobScheduler.inputInfoTracker.getInfo(time)
        jobScheduler.submitJobSet(JobSet(time, jobs, streamIdToInputInfos))
      case Failure(e) =>
        jobScheduler.reportError("Error generating jobs for time " + time, e)
    }
    eventLoop.post(DoCheckpoint(time, clearCheckpointDataLater = false))
  }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Foreground Service + JobScheduler 的方式可以通过同时利用前台服务和 JobScheduler实现应用保活,可以在系统资源充足的情况下执行任务,同时不会在通知栏显示持续的通知。下面是一个简单的实现方式: 1. 创建一个前台服务,将应用置于前台状态,并在 onStartCommand() 方法中返回 START_STICKY,表示服务被杀掉后会被系统重启。 ``` public class ForegroundService extends Service { ... @Override public int onStartCommand(Intent intent, int flags, int startId) { startForeground(NOTIFICATION_ID, new Notification()); return START_STICKY; } ... } ``` 2. 在 onCreate() 方法中创建一个 JobScheduler,定时执行任务。 ``` public class ForegroundService extends Service { ... private JobScheduler mJobScheduler; ... @Override public void onCreate() { super.onCreate(); mJobScheduler = (JobScheduler) getSystemService(Context.JOB_SCHEDULER_SERVICE); JobInfo jobInfo = new JobInfo.Builder(JOB_ID, new ComponentName(this, JobSchedulerService.class)) .setPeriodic(15 * 60 * 1000) // 每 15 分钟执行一次任务 .setRequiredNetworkType(JobInfo.NETWORK_TYPE_ANY) .build(); mJobScheduler.schedule(jobInfo); } ... } ``` 3. 创建一个 JobService,在 onStartJob() 方法中执行需要保持应用活跃的操作。 ``` public class JobSchedulerService extends JobService { ... @Override public boolean onStartJob(JobParameters params) { // 执行需要保持应用活跃的操作 return true; } ... } ``` 需要注意的是,为了避免被系统误识别为滥用权限,任务的执行间隔不宜过于频繁,同时需要适当调整任务的优先级和网络条件等参数,以确保任务可以在系统资源充足的情况下执行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值