问题:
生产环境出现bug 一个任务需要在每周一运行 出现每周日和周一运行两次
原因:
- 服务每小时从数据库更新任务列表 根据 周期(每天 每周 每月) 生成cron表达式 并添加任务;
- 添加任务前判断周期内有没有运行过 如果已经运行过本次不再添加;
- 部分任务有延时判断 处理逻辑是 :添加任务时候修改cron 任务为当天任务开始时间延后等待时间的每分钟运行的任务检查如果检查通过删除这个任务
问题出现在个周期判断的时间周:
java里面周的第一天是周日 在周日的时候生成周期会是下一周的周一和周日 导致上面的第二部失效
后面新加的延迟逻辑去除cron表达式后 (原来的cron表达式带有周一限制周日不会运行)延迟等待任务会在任务开始时间运行 出现上面的问题;
解决:
周的周期判断是周日前移一天 周期时间获取正确;
生成任务cron判断 如果是周月周期 不在运行时间那天不生成任务;
判断cron表达式 是否包含今天
CronExpression exp = new CronExpression("43 59 18 ? * 6 *");
Calendar c1 = Calendar.getInstance();
Calendar c2 = Calendar.getInstance();
Date nextValidTime = exp.getNextValidTimeAfter(new Date());
System.out.println(DateUtil.formatDateTime(nextValidTime));
c1.setTime(new Date());
c2.setTime(nextValidTime);
System.out.println((c1.get(Calendar.YEAR) == c2.get(Calendar.YEAR))
&& (c1.get(Calendar.MONTH) == c2.get(Calendar.MONTH))
&& (c1.get(Calendar.DAY_OF_MONTH) == c2.get(Calendar.DAY_OF_MONTH)));