spring boot 自带有定时任务 Schedule。可以满足简单的定时任务要求。
1 通过Spring boot 自带的入口开开启定时器
这种开启定时器的方式,也是最常用的方式。
在启动类上添加注解:@EnableScheduling ,
@EnableScheduling
@SpringBootApplication
public class App {
public static void main(String[] args) {
SpringApplication.run(App.class, args);
}
}
2 在定时任务的方法上进行配置
在方法 schedule 上加上注解:@Scheduled
注解中加入 cron 表达式。
@Component
public class EventFactorySchedule {
//每分钟的第10s启动
@Scheduled(cron = "10 0/1 * * * ?")
public void schedule() {
}
以上,完成 spring boot 项目的定时任务配置。
3 定时任务配置
@Schedule注解用来标记定时任务调试的方法,配置执行信息。
属性有:
- cron
- zone
- fixedDelay
- fixedRate
- initialDelay
注意,cron/fixedDelay/fixedRate 中必须有一个属性配置。
以下对各属性进行说明:
2.1 cron
这是一个时间表达式,指定了任务的同期执行时间
通过CRON表达式几乎可以完成任意的时间搭配,它包含了六或七个域,由前到后分别为:
Seconds : 可出现", - * /"四个字符,有效范围为0-59的整数
Minutes : 可出现", - * /"四个字符,有效范围为0-59的整数
Hours : 可出现", - * /"四个字符,有效范围为0-23的整数
DayofMonth : 可出现", - * / ? L W C"八个字符,有效范围为0-31的整数
Month : 可出现", - * /"四个字符,有效范围为1-12的整数或JAN-DEc
DayofWeek : 可出现", - * / ? L C #"四个字符,有效范围为1-7的整数或SUN-SAT两个范围。1表示星期天,2表示星期一, 依次类推
Year : 可出现", - * /"四个字符,有效范围为1970-2099年
下面简单举几个例子:
"0 0 12 * * ?" 每天中午十二点0分0秒触发
"0 15 10 * * ? 2025" 2025年的每天早上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触发
@Scheduled(cron = "0 0/1 * * * ?")
2.2 zone
指定时区,默认为空,获取服务器时区,一般不设置。
与 cron 表达示配合使用。
@Scheduled(cron = "0 0/1 * * * ?",
zone = "Asia/Colombo")
2.3 fixedDelay
上一次调用完成后,再次调用的等待时间,需要等待上一次调用完成。
@Scheduled(
//完成上一次执行后,间隔多长时间进行下一次任务的执行,时间:milliseconds
fixedDelay = 1000)
2.4 fixedRate
上一个调用开始后,再次调用的等待时间,不需要等待上一次调用完成。
注意:如果相隔再次任务之前无法保证完成一次调度,将会造成线程雪崩。
@Scheduled(
//上一次线程执行开始,间隔多长时间进行下一次任务的执行,时间:milliseconds
fixedRate = 1000)
2.5 initialDelay
初始线程开始调度的等待时间,即第一次执行的延迟时间。与 fixedRate,fixedDelay 配合使用。
最后,以上与时间相关的单位,都是 milliseconds 。