在项目中,我们经常需要用到定时任务,但是当定时任务过多或者执行时间过长等原因会造成定时任务执行的结果有差错,这是因为spring task任务有并行和串行之分,并行是指:一个定时任务,当执行时间到了的时候,立刻执行此任务,不管当前任务是否在执行中;串行是指:一个定时任务,当执行时间到了的时候,需要等待当前任务执行完毕,再去执行下一个任务。
spring task定时任务,默认是串行,scheduled默认的线程数是1。
1、spring task有一个重要的知识点:corn表达式
cron表达式:* * * * * *(共6位,使用空格隔开,具体如下) cron表达式:*(秒0-59) *(分钟0-59) *(小时0-23) *(日期1-31) *(月份1-12或是JAN-DEC) *(星期1-7或是SUN-SAT) CRON表达式 含义 "0 0 12 * * ?" 每天中午十二点触发 "0 15 10 ? * *" 每天早上10:15触发 "0 15 10 * * ?" 每天早上10:15触发 "0 15 10 * * ? *" 每天早上10:15触发 "0 15 10 * * ? 2005" 2005年的每天早上10:15触发 "0 * 14 * * ?" 每天从下午2点开始到2点59分每分钟一次触发 "0 0/5 14 * * ?" 每天从下午2点开始到2:55分结束每5分钟一次触发 "0 0/5 14,18 * * ?" 每天的下午2点至2:55和6点至6点55分两个时间段内每5分钟一次触发 "0 0-5 14 * * ?" 每天14:00至14:05每分钟一次触发 "0 10,44 14 ? 3 WED" 三月的每周三的14:10和14:44触发 "0 15 10 ? * MON-FRI" 每个周一、周二、周三、周四、周五的10:15触发
2、spring task 串行执行:每天10点15分,10点20分各有一个定时任务执行,那么当10点15分hzJiuZhouTongInvJob定时任务执行以后,如果时间到达在10点20分hzJiuZhouTongInvJob定时任务还没有执行完毕,将会导致cmsUserJob无法执行。
<task:scheduler id="hz_scheduler"/> <!--定时任务--> <task:scheduled-tasks scheduler="hz_scheduler"> <task:scheduled ref="hzJiuZhouTongInvJob" method="runJob" cron="0 15 10 * * ?"/> <task:scheduled ref="cmsUserJob" method="runJob" cron="0 20 10 * * ?"/> </task:scheduled-tasks>
3、spring task 并发执行:所以上述代码有多个任务需要执行,就需要设置线程数,spring task有个属性pool-size,设置pool-size即可解决串行执行的问题。
<task:scheduler id="hz_scheduler" pool-size="2"/> <!--定时任务--> <task:scheduled-tasks scheduler="hz_scheduler"> <task:scheduled ref="hzJiuZhouTongInvJob" method="runJob" cron="0 15 10 * * ?"/> <task:scheduled ref="cmsUserJob" method="runJob" cron="0 20 10 * * ?"/> </task:scheduled-tasks>