SpringBoot 定时任务遇到的坑

 更新时间:2017年11月11日 13:56:47   投稿:mrr  
这篇文章主要介绍了SpringBoot 定时任务遇到的坑,今天踩的这个坑和 cron 表达式有关,文中给大家介绍了cron 表达式的解释,需要的朋友一起看看吧

前言

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

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

@SpringBootApplication
@EnableScheduling
public class Application {
 public static void main(String[] args) {
  SpringApplication.run(Application.class, args);
 }
}

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

今天踩的这个坑和 cron 表达式有关,我们就先来看看 cron 表达式的解释吧:

Cron表达式是一个字符串,字符串以5或6个空格隔开,分为6或7个域,每一个域代表一个含义

解释

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

注: 这个是官方解释

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

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

那我就来贴代码和测试结果吧.

@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("听说今天是周日");
 }

测试结果:

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

按照上面的解释来讲,第六域是星期,并且值是1那么代表是周日运行,但是我的运行结果表明是周一运行,我在此表示很无奈。

最后我觉得用单词来表示周几,这样就不会出这种问题了,于是

@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("听说今天是周日");
 }
}

测试结果:

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

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

好了,下面看下Spring Boot 定时任务的使用

本文介绍在 Spring Boot 中如何使用定时任务,使用非常简单,就不做过多说明了。

下面是代码类:

package org.springboot.sample.config;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.scheduling.annotation.Scheduled;
/**
 * 定时任务配置类
 *
 * @author 单红宇(365384722)
 * @myblog http://blog.csdn.net/catoop/
 * @create 2016年3月21日
 */
@Configuration
@EnableScheduling // 启用定时任务
public class SchedulingConfig {
  private final Logger logger = LoggerFactory.getLogger(getClass());
  @Scheduled(cron = "0/20 * * * * ?") // 每20秒执行一次
  public void scheduler() {
    logger.info(">>>>>>>>>>>>> scheduled ... ");
  }
}

总结

以上所述是小编给大家介绍的SpringBoot 定时任务遇到的坑,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

相关文章

  • SpringBoot @JsonDeserialize自定义Json序列化方式

    SpringBoot @JsonDeserialize自定义Json序列化方式

    这篇文章主要介绍了SpringBoot @JsonDeserialize自定义Json序列化方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-10-10
  • Java基础之逻辑运算符知识总结

    Java基础之逻辑运算符知识总结

    今天带大家学习Java基础知识,文中对Java逻辑运算符进行了非常详细的介绍,有相关代码示例,对正在学习java的小伙伴很有帮助,需要的朋友可以参考下
    2021-05-05
  • Java利用Spire.XLS for Java实现删除Excel指定行或列

    Java利用Spire.XLS for Java实现删除Excel指定行或列

    在Java应用中处理Excel数据是常见的任务,而其中一项核心需求便是对工作表中的行或列进行管理,本文将深入探讨如何利用功能强大的Spire.XLS for Java库,轻松实现Excel行和列的删除操作,需要的可以了解下
    2025-09-09
  • 10个SpringBoot框架内置的实用功能详解

    10个SpringBoot框架内置的实用功能详解

    在 Spring Boot 开发中,框架内置的诸多实用功能犹如一把把利刃,能让开发者在项目的各个阶段都事半功倍,这些功能无需额外集成,通过简单配置或编码即可快速实现常见需求,下面将为你深入解析一系列极具价值的内置功能,需要的朋友可以参考下
    2025-06-06
  • 浅谈java泛型的作用及其基本概念

    浅谈java泛型的作用及其基本概念

    下面小编就为大家带来一篇浅谈java泛型的作用及其基本概念。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-08-08
  • ConcurrentHashMap线程安全及实现原理实例解析

    ConcurrentHashMap线程安全及实现原理实例解析

    这篇文章主要介绍了ConcurrentHashMap线程安全及实现原理实例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11
  • 深入理解Java设计模式之观察者模式

    深入理解Java设计模式之观察者模式

    这篇文章主要介绍了JAVA设计模式之观察者模式的的相关资料,文中示例代码非常详细,供大家参考和学习,感兴趣的朋友可以了解
    2021-11-11
  • Java环境变量的设置方法(图文教程)

    Java环境变量的设置方法(图文教程)

    想要成功配置Java的环境变量,那肯定就要安装JDK,才能开始配置的。
    2013-05-05
  • SpringDataJpa like查询无效的解决

    SpringDataJpa like查询无效的解决

    这篇文章主要介绍了SpringDataJpa like查询无效的解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • Springboot中的@ConditionalOnBean注解使用指南与最佳实践(工作原理)

    Springboot中的@ConditionalOnBean注解使用指南与最佳实践(工作原理)

    在使用Spring Boot进行开发时,大家应该都听说过条件注解Conditional Annotations,下面给大家聊聊Springboot中的@ConditionalOnBean注解使用指南与最佳实践,感兴趣的朋友一起看看吧
    2025-05-05

最新评论