基于Redis在定时任务里判断其他定时任务是否已经正常执行完的方案

前端之家收集整理的这篇文章主要介绍了基于Redis在定时任务里判断其他定时任务是否已经正常执行完的方案前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
执行的定时任务是基于其他定时任务计算得到的结果基础上做操作的,那么如何来确定其他存在数据依赖的定时任务已经执行完成呢?
在分布式环境里,可通过集群的redis来解决这个问题:
即,在跑批任务开始时,将任务key+当日凌晨时间组成的key值进行加1,例如:
1 redisOperator.getJedis().incr(key+ startDateStr);
2 redisOperator.setKeyExpireTime(key+ startDateStr,60*60*24);
跑批完成后,再将任务key+当日凌晨时间组成的key值减1,例如:
//跑批结束后自减
2 redisOperator.getJedis().decr(key+ startDateStr);
正常任务执行完,redis里对应的应该状态是0。
 1 //阻塞循环,一直等到另外的定时任务跑成功了,才继续。
 2 while (!checkCanRun(reportTime)) {
 3     int interval = 7200000;
 4     long sleepTime = System.currentTimeMillis();
 5     休眠
 6     logger.info("sendOperationDailyReportHandler sleep time = " + TimeUnit.MILLISECONDS.toSeconds(System.currentTimeMillis()-sleepTime) + " seconds");
 7     Thread.sleep(interval);
 8 }
 9 
10 
11 private boolean checkCanRun (DateTime reportTime) {
12 
13     String runningFinishKey = redisOperator.getValueByKey(key + dateStr);
14 
15     if ("0".equals(runningFinishKey )) {
16         return true17     }
18     false19 }

 

 

猜你在找的Java相关文章