SpringMVC定时任务注解实现@Schedule【良心文章】_spring boot

package com.axb.cheney.task;  
import java.sql.ResultSet;
import java.sql.SQLException;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

/**
* 心跳更新。启动时执行一次,之后每隔2秒执行一次
* @Scheduled(fixedRate = 1000*2)
*/

@Component
public class ManageSql {

@Scheduled(cron="0/30 * * * * ? ") //间隔5秒执行
public void test(){
System.out.println("定时任务开始啦,哈哈哈");
System.out.println("<<<---------结束执行HR数据同步任务--------->>>");
}
}

配置:

applicationContext.xml 中添加以下对应内容 :

1、xmlns 加下面的内容:

xmlns:task="http://www.springframework.org/schema/task"

2、然后xsi:schemaLocation加下面的内容:

http://www.springframework.org/schema/taskhttp://www.springframework.org/schema/task/spring-task-4.1.xsd

3、最后是我们的task任务扫描注解

<task:annotation-driven/>

4、配置的扫描位置是

<context:component-scan base-package="com.XXX.task"></context:component-scan>

添加后,如下图所示:

SpringMVC定时任务注解实现@Schedule【良心文章】_cron_02

扩展:定时时间的设置

如:“0/5 * * * * ?”

CronTrigger配置完整格式为: [秒] [分] [小时] [日] [月] [周] [年]

1

0-59

, - * /

2

0-59

, - * /

3

小时

0-23

, - * /

4

1-31

, - * ? / L W

5

1-12或JAN-DEC

, - * /

6

1-7或SUN-SAT

, - * ? / L W

7

empty 或1970-2099

, - * /

通配符说明:

* 表示所有值. 例如:在分的字段上设置 "*",表示每一分钟都会触发。

? 表示不指定值。使用的场景为不需要关心当前设置这个字段的值。

例如:要在每月的10号触发一个操作,但不关心是周几,所以需要周位置的那个字段设置为"?" 具体设置为 0 0 0 10 * ?

- 表示区间。例如 在小时上设置 "10-12",表示 10,11,12点都会触发。

, 表示指定多个值,例如在周字段上设置 "MON,WED,FRI" 表示周一,周三和周五触发

/ 用于递增触发。如在秒上面设置"5/15" 表示从5秒开始,每增15秒触发(5,20,35,50)。 在月字段上设置'1/3'所示每月1号开始,每隔三天触发一次。

L 表示最后的意思。在日字段设置上,表示当月的最后一天(依据当前月份,如果是二月还会依据是否是润年[leap]), 在周字段上表示星期六,相当于"7"或"SAT"。如果在"L"前加上数字,则表示该数据的最后一个。例如在周字段上设置"6L"这样的格式,则表示“本月最后一个星期五"

W 表示离指定日期的最近那个工作日(周一至周五). 例如在日字段上设置"15W",表示离每月15号最近的那个工作日触发。如果15号正好是周六,则找最近的周五(14号)触发, 如果15号是周未,则找最近的下周一(16号)触发.如果15号正好在工作日(周一至周五),则就在该天触发。如果指定格式为 "1W",它则表示每月1号往后最近的工作日触发。如果1号正是周六,则将在3号下周一触发。(注,"W"前只能设置具体的数字,不允许区间"-").

# 序号(表示每月的第几个周几),例如在周字段上设置"6#3"表示在每月的第三个周六.注意如果指定"#5",正好第五周没有周六,则不会触发该配置(用在母亲节和父亲节再合适不过了) ;

小提示:

'L'和 'W'可以组合使用。如果在日字段上设置"LW",则表示在本月的最后一个工作日触发;

周字段的设置,若使用英文字母是不区分大小写的,即MON 与mon相同;

@参考文献:

https://wuzhuti.cn/850.html/comment-page-1/

https://wuzhuti.cn/447.html


cron表达式规则:




  • * 字段 允许值 允许的特殊字符
  • 秒 0-59 , - * /
  • 分 0-59 , - * /
  • 小时 0-23 , - * /
  • 日期 1-31 , - * ? / L W C
  • 月份 1-12 或者 JAN-DEC , - * /
  • 星期 1-7 或者 SUN-SAT , - * ? / L C #
  • 年(可选) 留空, 1970-2099 , - * /
  • - 区间
  • * 通配符
  • ? 你不想设置那个字段

  • 1 Seconds (0-59)
  • 2 Minutes (0-59)
  • 3 Hours (0-23)
  • 4 Day of month (1-31)
  • 5 Month (1-12 or JAN-DEC)
  • 6 Day of week (1-7 or SUN-SAT)
  • 7 Year (1970-2099)
  • 取值:可以是单个值,如6;
  • 也可以是个范围,如9-12;
  • 也可以是个列表,如9,11,13
  • 也可以是任意取值,使用*



CRON表达式 示例:




  • "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触发
  • "0 * * * * ?" 每分钟(0点0时0分)触发一次
  • "0 0 * * * ?" 每小时(0点0时0分)触发一次


fixedDelay = 5000 每秒触发一次 这个周期是以上一个调用任务的完成时间为基准,在上一个任务完成之后,5s后再次执行

fixedRate = 5000 每3秒触发一次 固定速率执行,以上一个任务开始时间为基准,从上一任务开始执行后5s再次调用

initialDelay=3000 启动后延迟3秒后开始首次触发


还可以通过使用zone属性来指定cron表达式被调用的时区。

SpringMVC定时任务注解实现@Schedule【良心文章】_spring_03

注意:

1、spring的注解@Scheduled 需要写在实现方法上;

2、定时器的任务方法不能有返回值(如果有返回值,spring初始化的时候会告诉你有个错误、需要设定一个proxytargetclass的某个值为true),不能指向任何的参数;

3、如果该方法需要与应用程序上下文的其他对象进行交互,通常是通过依赖注入来实现;

4、实现类上要有组件的注解@Component。


延伸了解:spring定时器使用注解@Scheduled执行任务,fixedDelay、fixedRate和cron区别

注解@Scheduled 可以作为一个触发源添加到一个方法中,例如,以下的方法将以一个固定延迟时间5秒钟调用一次执行,这个周期是以上一个调用任务的完成时间为基准,在上一个任务完成之后,5s后再次执行:

@Scheduled(fixedDelay=5000)

public void doSomething() {

// something that should execute periodically

}

如果需要以固定速率执行,只要将注解中指定的属性名称改成fixedRate即可,以下方法将以一个固定速率5s来调用一次执行,这个周期是以上一个任务开始时间为基准,从上一任务开始执行后5s再次调用:

@Scheduled(fixedRate=5000)

public void doSomething() {

// something that should execute periodically

}

对于固定延迟和固定速率的任务,可以指定一个初始延迟表示该方法在第一被调用执行之前等待的毫秒数:

@Scheduled(initialDelay=1000, fixedRate=5000)

public void doSomething() {

// something that should execute periodically

}

如果简单的定期调度不能满足,那么cron表达式提供了可能。例如,下面的方法将只会在工作日执行:

@Scheduled(cron="*/5 * * * * MON-FRI")

public void doSomething() {

// something that should execute on weekdays only

}

还可以通过使用zone属性来指定cron表达式被调用的时区。




想要实时关注更多干货好文,扫描下图关注:

SpringMVC定时任务注解实现@Schedule【良心文章】_spring_04

SpringMVC定时任务注解实现@Schedule【良心文章】_quartz_05