开启定时任务步骤流程:
在启动类添加注解;(注意:千万不要忘记!)
@EnableScheduling
在具体的方法上添加定时任务注解
@Scheduled(cron = “0 0 */3 * * ?”) // 每3个小时触发一次
定时任务开启时间:
常用的:
@Scheduled(cron = “0 0/1 * * * ?” ) //每一分钟启动一次
@Scheduled(cron = “0 0 */1 * * ?” ) // 每1个小时触发一次
常用的几种配置格式:
格式 | 描述 |
---|---|
0 0 10,14,16 * * ? | 每天上午10点,下午2点,4点 |
0 0/30 9-18 * * ? | 朝九晚六工作时间内每半小时 |
0 0 12 ? * WED | 表示每个星期三中午12点 |
0 0 12 * * ? | 每天中午12点触发 |
0 30 10 * * ? | 每天上午10:30触发 |
0 30 10 * * ? 2022 | 2022年的每天上午10:30触发 |
0 * 14 * * ? | 在每天下午2点到下午2:59期间的每1分钟触发 |
0 0/5 14 * * ? | 在每天下午2点到下午2:55期间的每5分钟触发 |
0 “0/5 14,18 * * ? | 在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发 |
0 30 10 ? * MON-FRI | 周一至周五的上午10:30触发 |
0 30 10 15 * ? | 每月15日上午10:30触发 |
0 30 10 L * ? | 每月最后一日的上午10:30触发 |
0 30 10 ? * 6L | 每月的最后一个星期五上午10:30触发 |
0 30 10 ? * 6L 2022-2023 | 2022年至2023年的每月的最后一个星期五上午10:30触发 |
0 30 10 ? “* 6#3 | 每月的第三个星期五上午10:30触发 |
特殊符号解释:
" 阿拉伯数字 ":数值,出现在标识符位置的数字代表对应值,比如第一个2代表两点,第二个2代表二号.
" * “” :通配,语义相当于每… 比如第五个位置的 *就表示每月都会执行(相当于1-12)
" ? " :忽略,语义相当于不管…
比如第六个位置的?就表示不管当前是周几就会执行。至于为什么会有这种用法,我觉得应该是因为它和其他的字符可能会冲突。如果用*的话表示周一到周日都会执行,此时其他语义就不明确了,所以如果用不上星期的话一般给它用一个?表示
" / " :间隔,语义相当于每隔… 比如例2中的第三个位置的2/5就表示从2点开始每隔五小时
" - " :区间,语义相当于第…到…的每… 比如例2中的第二个位置的15-20就表示第15分钟到20分钟之间的每分钟
" , " :枚举,语义相当于第…和… 比如例2中的第一个位置的15,20,40就表示第15秒、20秒和40秒
" L " :最后(last),语义相当于最后一个 比如例2中的第四个位置的L就表示最后一天
" W " :工作日,字面意思,就是工作日 比如例3中的第四个位置的15W表示15号附近最近的工作日,如果15号刚好是工作日那就15号触发,如果15号是周六那就14号触发,如果15号是周日那就16号触发。前面不带数字就是所有匹配的工作日。
" # " :周定位,语义相当于每月的第几个周几 比如例4中的第六个位置的2#3就表示第三个周一。
来源地址:https://blog.csdn.net/lkm987654321/article/details/129260508