之前做的一个用quartz调度周期任务的系统,我在测试的时候偶然发现quartz有时会错过第一次触发(当时我设置的是每分钟执行一次,开始时间在添加进quartz的时间之前),我找了很多博客论坛,也在百度和Stack Overflow搜索,但都没有找到有这样问题。只能一点点调试,找问题出在哪里。最后终于窥见了一些端倪,总结如下:
一,出现的问题的详细描述
1.首先我设置的调度策略是withMisfireHandlingInstructionDoNothing,意思是不触发立即执行,并且错过触发时间的话等待下次Cron触发频率到达时刻开始按照Cron频率依次执行。
2.启动调度系统后,我多次把任务添加进调度系统,有些能正确执行,有些则不会执行第一次触发,当时我的cron是0 * * * * ? *(在每分钟的0秒触发),开始时间设置得很靠前,结束时间设置在几天之后。我发现总有那么一个时间分界线,在这个分界线之前添加进quartz的任务正常,在这个分界线之后添加进quartz的任务就会出问题,每次重启调度系统之后这个分界线就会有变动。有时是20多秒,有时40多秒,不固定。
3.如果我把开始时间设置在我把任务添加进quartz的时间之后,就不会出现问题。(比如说我是在11:56:02把任务添加进调度系统的,如果开始时间是11:42:02就会有问题,如果是11:57