定时任务一般会存在中大型企业级项目中,为了减少服务器、数据库的压力往往会采用时间段性的去完成某些业务逻辑。比较常见的就是金融服务系统推送回调,一般支付系统订单在没有收到成功的回调返回内容时会持续性的回调,这种回调一般都是定时任务来完成的。还有就是报表的生成,我们一般会在客户访问量过小的时候来完成这个操作,那往往都是在凌晨。这时我们也可以采用定时任务来完成逻辑。SpringBoot为我们内置了定时任务,我们只需要一个注解就可以开启定时为我们所用。
1、pom包配置
引入spring-boot-starter包即可
org.springframework.boot
spring-boot-starter
org.springframework.boot
spring-boot-starter-test
test
2、启动类开启定时
在启动类上面加上@EnableScheduling即可开启定时
@SpringBootApplication
@EnableScheduling
public class DemoApplication {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
}
}
3、创建定时任务实现类
3.1使用 fixedRate 属性
该属性的含义是上一个调用开始后再次调用的延时(不用等待上一次调用完成),这样就会存在重复执行的问题,所以不是建议使用,但数据量如果不大时在配置的间隔时间内可以执行完也是可以使用的。
// 注解@Compoment用来标明这是一个被Spring管理的Bean
@Component
public class SchedulerTask {
private static final SimpleDateFormat dataform = new SimpleDateFormat("HH:mm:ss");
@Scheduled(fixedRate = 1000*1)
public void fixeReate() throws Exception{
Thread.sleep(2000);
System.out.println("fixeRate测试时间:" + dataform.format(new Date()));
}
输出结果:
2018-05-28 17:52:29.699 INFO 6212 --- [main] com.example.demo.DemoApplication :
fixeRate测试时间:17:52:31
fixeRate测试时间:17:52:33
fixeRate测试时间:17:52:35
3.2使用 fixedDelay 属性
/*
*上一个方法调用完成后再次调用的延时调用
*/
@Scheduled(fixedDelay = 1000*1)
public void fixedDelay() throws Exception{
Thread.sleep(3000);
System.out.println("fixedDelay测试时间:" + new Date(System.currentTimeMillis()));
}
控制台输出:
2018-05-28 17:18:06.552 INFO 5304 --- [main] com.example.demo.DemoApplication :
fixedDelay测试时间:Mon May 28 17:18:09 CST 2018
fixedDelay测试时间:Mon May 28 17:18:13 CST 2018
fixedDelay测试时间:Mon May 28 17:18:17 CST 2018
3.3使用 initialDelay 属性
该属性的作用是第一次执行延迟时间,只是做延迟的设定,并不会控制其他逻辑,所以要配合fixedDelay或者fixedRate来使用。
@Scheduled(initialDelay = 1000*10,fixedDelay = 1000*2)
public void initialDelay() throws Exception{
System.out.println("initialDelay测试时间:" + new Date(System.currentTimeMillis()));
}
输出结果:
2018-05-28 17:28:48.405 INFO 2524 --- [main] com.example.demo.DemoApplication :
initialDelay测试时间:Mon May 28 17:28:58 CST 2018
initialDelay测试时间:Mon May 28 17:29:00 CST 2018
initialDelay测试时间:Mon May 28 17:29:02 CST 2018
项目成功启动的时间为28:48而第一次输出的时间则是28:58,证明了我们配置的延迟时间生效了。第一次加载完成后之后就是每间隔2秒钟执行一边该方法。
3.4使用 cron 属性
/*
*每小时的第10分钟执行该方法
*/
@Scheduled( cron = "0 10 * * * *")
public void cron() throws Exception{
System.out.println("cron测试时间:" + new Date(System.currentTimeMillis()));
}
这是一个时间表达式,可以通过简单的配置就能完成各种时间的配置,我们通过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 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触发
参考
SpringBoot使用@Scheduled创建定时任务