quartz使用过程中的一个尴尬问题

话说我想做一个任务,在每天晚上的1:30分执行,下面这段代码有毛病吗?

@Bean(name = "jobTrigger")
    public CronTriggerFactoryBean cronJobTrigger(JobDetail jobDetail){
        CronTriggerFactoryBean trigger = new CronTriggerFactoryBean();
        trigger.setJobDetail(jobDetail);
        trigger.setCronExpression("* 30 1 * * ?");
        trigger.setName("cal-ushimata");
        return trigger;
    }

看了好久也没看出问题,或者说一直没意识到会是这里有问题。却在执行时噼里啪啦跑了很多次,一直以为是并发的问题,找了很多相关的资料,包括

1.在job类上加注解@DisallowConcurrentExecution

2.在application.properties里加org.quartz.jobstore.acquireTriggerWithinLock=true

3.JobDetailFactoryBean里面jobDetail.setConcurrent(false);是早就加过的

都没能达到预计的结果

偶然间回过头再去看cron的规则,发现秒位不能用*,不然就表示在1:30分的那一分钟里面都会不停的触发了,事实上也是这样,1分钟过后就没有任务进来了。正确的写法应该是这样

@Bean(name = "jobTrigger")
    public CronTriggerFactoryBean cronJobTrigger(JobDetail jobDetail){
        CronTriggerFactoryBean trigger = new CronTriggerFactoryBean();
        trigger.setJobDetail(jobDetail);
        trigger.setCronExpression("0 30 1 * * ?");
        trigger.setName("cal-ushimata");
        return trigger;
    }

其实也是跟之前在linux上设置crontab的习惯有点关系,crontab没有秒位,某个时间触发就设置小时和分钟就可以了,没有意识到秒也需要设置。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章