SpringBoot 定时任务踩坑记录

本文记录了作者在使用 Spring Boot 的 Schedule 模块时遇到的问题,特别是在使用 cron 表达式指定任务执行频率时出现的星期表示错误。作者通过测试验证了官方文档中的星期表示方式与实际运行结果不符,并提供了修正方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

springboot已经支持了定时任务Schedule模块,一般情况已经完全能够满足我们的实际需求。今天就记录一下我使用 schedule 时候踩的坑吧。

想要使用定时,我们首先要开启支持,其实就是在启动类上面加个注解就 Ok。

1
2
3
4
5
6
7
@SpringBootApplication
@EnableScheduling
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

这篇博客的主题是记录踩的坑,具体定时任务怎么使用我就不写了

今天踩的这个坑和 cron 表达式有关,我们就先来看看 cron 表达式的解释吧:
Cron表达式是一个字符串,字符串以5或6个空格隔开,分为6或7个域,每一个域代表一个含义

解释

1
2
3
4
5
6
7
8
* 第一位,表示秒,取值0-59
* 第二位,表示分,取值0-59
* 第三位,表示小时,取值0-23
* 第四位,日期天/日,取值1-31
* 第五位,日期月份,取值1-12
* 第六位,星期,取值1-7,星期一,星期二...,注:不是第1周,第二周的意思
          另外:1表示星期天,2表示星期一。
* 第7为,年份,可以留空,取值1970-2099
1
2
3
4
5
(*)星号:可以理解为每的意思,每秒,每分,每天,每月,每年...
(?)问号:问号只能出现在日期和星期这两个位置,表示这个位置的值不确定,每天3点执行,所以第六位星期的位置,我们是不需要关注的,就是不确定的值。同时:日期和星期是两个相互排斥的元素,通过问号来表明不指定值。比如,110日,比如是星期1,如果在星期的位置是另指定星期二,就前后冲突矛盾了。
(-)减号:表达一个范围,如在小时字段中使用“10-12”,则表示从1012点,即10,11,12
(,)逗号:表达一个列表值,如在星期字段中使用“1,2,4”,则表示星期一,星期二,星期四
(/)斜杠:如:x/y,x是开始值,y是步长,比如在第一位(秒) 0/15就是,从0秒开始,每15秒,最后就是015304560    另:*/y,等同于0/y

注: 这个是官方解释

1
2
3
4
5
6
0 0 3 * * ?     每天3点执行
0 5 3 * * ?     每天35分执行
0 5 3 ? * *     每天35分执行,与上面作用相同
0 5/10 3 * * ?  每天3点的 5分,15分,25分,35分,45分,55分这几个时间点执行
0 10 3 ? * 1    每周星期天,310分 执行,注:1表示星期天   
0 10 3 ? * 1#3  每个月的第三个星期,星期天 执行,#号只能出现在星期的位置

在此我要说明,springBoot 中的 schedule 支持的 cron 表达式和这个不太相符,官方说的星期表示,1是周天,依次类推,但是我在测试过程中,1实际上代表的就是周一,口说无凭
那我就来贴代码和测试结果吧.

1
2
3
4
5
6
7
8
@Component
@EnableScheduling
public class Task {
    private static final Logger LOGGER = MyLogger.getLogger(Task.class);
    @Scheduled(cron = "0 46 20 ? * 1")
    public void task() {
        LOGGER.info("听说今天是周日");
    }

测试结果:

1
2017-05-08 20:46:00.006  INFO 18838 --- [pool-1-thread-1] com.yiyexy.task.Task                     : 听说今天是周日

按照上面的解释来讲,第六域是星期,并且值是1那么代表是周日运行,但是我的运行结果表明是周一运行,我在此表示很无奈。
最后我觉得用单词来表示周几,这样就不会出这种问题了,于是

1
2
3
4
5
6
7
8
9
@Component
@EnableScheduling
public class Task {
    private static final Logger LOGGER = MyLogger.getLogger(Task.class);
    @Scheduled(cron = "0 49 20 ? * MON")
    public void task() {
        LOGGER.info("听说今天是周日");
    }
}

测试结果:

1
2017-05-08 20:49:00.005  INFO 18864 --- [pool-1-thread-1] com.yiyexy.task.Task                     : 听说今天是周日

好了,这个坑就记录到这吧,最后奉上一句,时间是检验真理的唯一标准。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值