使用springboot解决定时任务非常简单,只需要几个注解就能实现。
1.@EnableScheduling (设置定时器开关启动)
2.@Scheduled(cron = “0 0 0 * * ?”) (设置定时启动时间)
3.@Configuration (表明该类是一个配置类)
springboot使用注解设置定时器的用法大致相同,一种是将定时器开关加在了启动类上,第二种是将开关加在一个类上,然后将此类声明成配置文件。
方法一:
(1)直接在springboot启动类上添加注解 @EnableScheduling 开启定时器总开关。
@EnableScheduling
@SpringBootApplication
public class DouDouApplication extends SpringBootServletInitializer
{
public static void main(String[] args)
{
SpringApplication.run(DouDouApplication.class, args);
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
(2)给要执行的方法上添加注解 @Scheduled(cron = “0 0 0 * * ?”) ,cron 参数是设置执行时间。
下面设定了一个定时任务,每5秒在控制台显示一次当前时间。
(注意:这里是我自己新建的一个定时器类,为了让spring扫描到这个定时器类,所以要在该类上加上一个注解 @Component)
@Component
public class TaskTimer {
@Scheduled(cron = "0/5 * * * * ?")
public void myTimes(){
SimpleDateFormat dateFormat1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
System.out.println(dateFormat1.format(new Date()));
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
启动项目后,控制台便会出现已经启动的定时任务信息,如下:
方法二:
直接在定时器类上添加注解 @Configuration 、@EnableScheduling,表示这个类是配置文件并且同时开启定时开关,但项目运行时扫描这个配置文件便会自动启动定时任务。(注意:这里就不需要在该类上添加注解 @Component,因为已经有了 @Configuration 注解)
记得也要给要执行的定时方法上添加注解 @Scheduled(cron = “0 0 0 * * ?”)
@EnableScheduling
@Configuration
public class TaskTimer {
@Scheduled(cron = "0/5 * * * * ?")
public void myTimes(){
SimpleDateFormat dateFormat1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
System.out.println(dateFormat1.format(new Date()));
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
cron表达式详解
cron表达式有至少6个(也可能7个)有空格分隔的时间元素。
格式: cron = [ 秒 ] [ 分钟 ] [ 小时 ] [ 日 ] [ 月 ] [ 周(星期)] [ 年份 ]
序号 | 元素 | 值 | 通配符 |
---|---|---|---|
1 | 秒 | 0-59 | - * / |
2 | 分钟 | 0-59 | - * / |
3 | 小时 | 0-23 | - * / |
4 | 日 | 1-31 | - * ? / L W |
5 | 月 | 1-12 or JAN-DEC | ,- * / |
6 | 周(星期) | 1~7 1=SUN 或 SUN,MON,TUE,WED,THU,FRI,SAT | ,- * ? / L # |
7 | 年份 | 1970-2099 | ,- * / |
通配符详解
序号 | 通配符 | 备注 |
---|---|---|
1 | * | 表示所有值,如:秒的位置上是 * ,则代表每一秒都会执行 |
2 | ? | 表示不指定值,如:年的位置上是 ?,则代表不知道某一年 |
3 | - | 表示区间,如:小时的位是1-2,代表小时为1,2都会执行 |
4 | , | 表示指定多个值,如:小时为1,2,3时都会运行 |
5 | L | 表示最后的意思,如:分钟是L代表每一小时最后一分钟都会运行 |
6 | W | 表示离指定日期的最近那个工作日,如:10W代表离10号最近的一个工作日运行 |
7 | # | 表示第几个,如:2#3 代表二月的第三周执行 |
下面是常见的 corn 表达式:
表达式 | 备注 |
---|---|
*/5 * * * * ? | 每隔5秒执行一次 |
0 */1 * * * ? | 每隔1分钟执行一次 |
0 0 23 * * ? | 每天23点执行一次 |
0 0 1 1 * ? | 每月1号凌晨1点执行一次 |
0 0 23 L * ? | 每月最后一天23点执行一次 |
0 0 1 ? * L | 每周星期天凌晨1点执行一次 |
0 15,25,35 * * * ? | 在15分、25分、35分执行一次 |
0 * 16 * * ? | 每天下午16点钟开始到16点59分结束这么一个时间段 |
0 0/5 16 * * ? | 每天下午16点到16点55分之间每5分钟触发一次 |
0 0/5 14,18 * * ? | 每天下午14点到14点55分 和18点到18点55分之间 每5分钟触发一次 |
0 0-5 14 * * ? | 每天下午14点开始到14点05结束 |
0 10,44 14 ? 3 WED | 每年三月份的每个周三下午14点10分和14点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分 |
0 0 12 1/5 * ? | 每个月从第一天开始每隔5天中午12点触发一次 |
0 11 11 11 11 ? | 每年11月11号11点11分 |
0 0 0,13,18,21 * * ? | 每天的0点、13点、18点、21点都执行一次 |
0 0/30 9-17 * * ? | 朝九晚五工作时间内每半小时 |
0 0 12 * * ? | 每天中午12点触发 |
0 15 10 ? * * | 每天上午10:15触发 |
0 0 23 * * ? | 每天 |
0 59 23 ? * SUN | 每周 |
0 59 23 L * ? | 每月 |
0 59 23 L 3,6,9,12 ? | 每季度 |
0 0 0 31 12 ? | 每年 |
在线 cron 表达式生成工具:https://qqe2.com/cron/index