在项目开发中咱们常常须要一些定时任务来处理一些特殊的任务,好比定时检查订单的状态、定时同步数据等等。java
在 Spring Boot 中使用 @Scheduled 注解建立定时任务很是简单,只须要两步操做就能够建立一个定时任务:spring
一、在定时任务类上增长
@EnableScheduling
注解
二、在要执行任务的方法上增长@Scheduled
注解bash
下面是我使用 cron 表达式建立一个简单的定时任务:工具
import java.text.SimpleDateFormat; import java.util.Date; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; @Component // 启用定时任务 @EnableScheduling public class ScheduledTasks { private static final Logger log = LoggerFactory.getLogger(ScheduledTasks.class); private static final SimpleDateFormat dateFormat = new SimpleDateFormat("HH:mm:ss"); // 每 5 秒执行一次任务。 @Scheduled(cron = "0/5 * * * * ?") public void performingTasks() { log.info("执行定时任务时间:{}", dateFormat.format(new Date())); } }
启动运行项目之后控制台会每隔五秒打印一条记录。测试
2019-07-25 11:12:00.343 INFO 15988 --- [pool-1-thread-1] c.m.s.s.a.controller.ScheduledTasks : 执行定时任务时间:11:12:00 2019-07-25 11:12:05.343 INFO 15988 --- [pool-1-thread-1] c.m.s.s.a.controller.ScheduledTasks : 执行定时任务时间:11:12:05 2019-07-25 11:12:10.343 INFO 15988 --- [pool-1-thread-1] c.m.s.s.a.controller.ScheduledTasks : 执行定时任务时间:11:12:10 2019-07-25 11:12:15.343 INFO 15988 --- [pool-1-thread-1] c.m.s.s.a.controller.ScheduledTasks : 执行定时任务时间:11:12:15 2019-07-25 11:12:20.343 INFO 15988 --- [pool-1-thread-1] c.m.s.s.a.controller.ScheduledTasks : 执行定时任务时间:11:12:20 2019-07-25 11:12:25.342 INFO 15988 --- [pool-1-thread-1] c.m.s.s.a.controller.ScheduledTasks : 执行定时任务时间:11:12:25
一些经常使用的 Cron 表达式例子code
表达式 | 说明 |
---|---|
0/2 * * * * ? | 表示每 2 秒执行任务 |
0 0/2 * * * ? | 表示每 2 分钟执行任务 |
0 0 2 1 * ? | 表示在每个月的 1 日的凌晨 2 点调整任务 |
0 15 10 ? * MON-FRI | 表示周一到周五天天上午 10:15 执行做业 |
0 15 10 ? 6L 2002-2006 | 表示 2002-2006 年的每月的最后一个星期五上午 10:15 执行做 |
0 0 10,14,16 * * ? | 天天上午 10 点,下午 2 点,4 点 |
0 0/30 9-17 * * ? | 朝九晚五工做时间内每半小时 |
0 0 12 ? * WED | 表示每一个星期三中午 12 点 |
0 0 12 * * ? | 天天中午 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 期间的每 1 分钟触发 |
0 0/5 14 * * ? | 在天天下午 2 点到下午 2:55 期间的每 5 分钟触发 |
0 0/5 14,18 * * ? | 在天天下午 2 点到 2:55 期间和下午 6 点到 6:55 期间的每 5 分钟触发 |
0 0-5 14 * * ? | 在天天下午 2 点到下午 2:05 期间的每 1 分钟触发 |
0 10,44 14 ? 3 WED | 每一年三月的星期三的下午 2:10 和 2:44 触发 |
0 15 10 ? * MON-FRI | 周一至周五的上午 10:15 触发 |
0 15 10 15 * ? | 每个月 15 日上午 10:15 触发 |
0 15 10 L * ? | 每个月最后一日的上午 10:15 触发 |
0 15 10 ? * 6L | 每个月的最后一个星期五上午 10:15 触发 |
0 15 10 ? * 6L 2002-2005 | 2002 年至 2005 年的每个月的最后一个星期五上午 10:15 触发 |
0 15 10 ? * 6#3 | 每个月的第三个星期五上午 10:15 触发 |
@Scheduled
除了支持 cron 表达式之外还有不少的其余使用方法:orm
// 上一次开始执行时间点后 1 秒再次执行。 @Scheduled(fixedRate = 1000) // 上一次执行完毕时间点后 1 秒再次执行。 @Scheduled(fixedDelay = 1000) // 第一次延迟 2 秒执行,而后在上一次执行完毕时间点后 1 秒再次执行。 @Scheduled(initialDelay = 2000, fixedDelay = 1000)
网上也有一些 Cron 测试工具能够验证定时任务的执行时间:
一、https://tool.lu/crontab/
二、http://cron.qqe2.com/crontab