SpringBoot(十二)定时任务实现

一、springboot定时任务实现——方式1

在项目开发中,经常需要定时任务来帮助我们来做一些内容,比如定时发送短息/站内信、数据汇总统计、业务监控等。

1、启动类开启定时任务

@SpringBootApplication
@EnableScheduling//开启定时任务
public class ApplicationStarter {
  public static void main(String[] args) {
      SpringApplication.run(ApplicationStarter.class,args);
  }
}

2、创建定时任务实现类

@Component
public class SchedulingTask {
    private static final SimpleDateFormat f = new SimpleDateFormat("HH:mm:ss");
    
    @Scheduled(fixedRate = 5000) //开始执行时间5秒在执行,每过5秒执行一次方法
    //@Scheduled(fixedDelay = 5000) //每过5秒执行方法,方法中休眠了3秒,然后打印,必须等方法执行完,相当于每八秒执行一次
    //@Scheduled(initialDelay = 1000 ,fixedRate = 5000)//第一次延迟1秒后执行(程序启动后延迟1秒),之后按fixedRate的规则每5秒执行一次
    public void processFixedRate() {
        try {
            Thread.sleep(3000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("Scheduled-fixedRate 方式:开始定时任务,现在时间:"+f.format(new Date()));
    }
}

3、测试:

运行工程控制台打印

Scheduled-fixedRate 方式:开始定时任务,现在时间:14:12:37
Scheduled-fixedRate 方式:开始定时任务,现在时间:14:12:42
Scheduled-fixedRate 方式:开始定时任务,现在时间:14:12:47
Scheduled-fixedRate 方式:开始定时任务,现在时间:14:12:52
Scheduled-fixedRate 方式:开始定时任务,现在时间:14:12:57
Scheduled-fixedRate 方式:开始定时任务,现在时间:14:13:02

4、@Scheduled参数说明

在上面的例子中,使用了@Scheduled(fixedRate = 5000)注解来定义每5秒执行的任务,对于@Scheduled的使用可以总结如下几种方式: fixedRate 说明

@Scheduled(fixedRate = 5000) 上一次开始执行时间点之后5秒在执行

@Scheduled(fixedDelay = 5000) 上一次执行方法完毕时间点之后5秒执行

@Scheduled(initialDelay = 1000 ,fixedRate = 5000)第一次延迟1秒后执行(程序启动后延迟1秒),之后按fixedRate的规则每5秒执行一次

二、springboot定时任务实现——方式2

SpringBoot 使用定时任务@Scheduled-cron方式

1、定时任务实现方法

//每五秒执行一次     秒 分 时 天 月 星期
@Scheduled(cron = "*/5 * * * * ?")
public void processCron() {
     System.out.println("Scheduled-cron 方式:开始定时任务,现在时间:"+f.format(new Date()));
  }

2、参数说明

2.1位数说明

一个cron表达式有至少6位(也可能7位)数字组成(每个数字称作元素),用空格分隔的时间元素。

按顺序依次为:

1、秒(取值范围: 0~59,不能超过59,若取值为60的话,也会提示表达式不合格)

2、分钟(0~59)

3、小时(0~23)

4、天(1~31)

5、月(0~11)

6、星期(1~7 == SUN,MON,TUE,WED,THU,FRI,SAT)(周一到周六是2-7,周一是1)

7、年份(1970-2199)

2.2 cron表达式规则

每一个域都使用数字,但还可以出现如下特殊字符,它们的含义是:

(1)*:表示匹配该域的任意值。假如在Minutes(分钟)域使用, 即表示每分钟都会触发事件。

(2)?:只能用在DayofMonth(日期)和DayofWeek(星期)两个域。它也匹配域的任意值,但实际不会。因为DayofMonth和DayofWeek会相互影响。例如想在每月的20日触发调度,不管20日到底是星期几,则只能使用如下写法: 13 13 15 20 * ?, 其中最后一位只能用?,而不能使用 *,如果使用 *表示不管星期几都会触发,实际上并不是这样。

如果确定了日期(哪一天),那就知道了是周几了,所以星期可以为?写法: 13 13 15 20 * ?:每月得20号下午三点13分13秒执行,就跟周几没关系了所以用?如果使用 *表示不管星期几都会触发

如果确定了周几,那么日期可以设置为?,* 0 0 12* ? * WED :每月的周三中午十二点执行

(3)-:表示范围。例如在Minutes域使用5-20,表示从5分到20分钟每分钟触发一次

(4)/:表示起始时间开始触发,然后每隔固定时间触发一次。例如在Minutes域使用5/20,则意味着5分钟触发一次,而25,45等分别触发一次.

(5),:表示列出枚举值。例如:在Minutes域使用5,20,则意味着在5和20分每分钟触发一次。

(6)L:表示最后,只能出现在DayofWeek和DayofMonth域。如果在DayofWeek域使用5L,意味着在最后的一个星期四触发。

(7)W:表示有效工作日(周一到周五),只能出现在DayofMonth域,系统将在离指定日期的最近的有效工作日触发事件。例如:在 DayofMonth使用5W,如果5日是星期六,则将在最近的工作日:星期五,即4日触发。如果5日是星期天,则在6日(周一)触发;如果5日在星期一到星期五中的一天,则就在5日触发。另外一点,W的最近寻找不会跨过月份 。

(8)LW:这两个字符可以连用,表示在某个月最后一个工作日,即最后一个星期五。

(9)#:用于确定每个月第几个星期几,只能出现在DayofMonth域。例如在4#2,表示某月的第二个星期三。

3、熟悉规则举例:

例子如下: 秒 分 时 天 月 星期 年

* * * * * ? *       解释: 每秒执行一次(所有元素都可以是任意值,那就从秒元素开始,以每秒为单位触发);如果前几位用数值定死        了,那就以本位元素为单位来进行触发
0 * * * * ?         解释: 每1分钟触发一次(秒元素定死了,那就从分钟元素开始,*可以为分钟元素取值范围内的任意值,那就以每分钟为单位触发)
0/40 * * * * ?     解释: 增量后的值遇到当前元素取值范围最大值时,会被置为取值范围最小值   例: 0:00:00、0:00:40、0:01:00、0:01:40、0:02:00、......
​
0 0 * * * ?         解释: 每1小时触发一次(秒元素和分钟元素都定死了,那就从小时元素开始,以每小时为单位触发)
0 0 0 * * ?         解释: 每天凌晨0:00:00运行一次(秒、分、时元素都定死了,那就从日期元素开始,以每天为单位触发)
0 0 0 1 * ?         解释: 每月1号凌晨触发
​
0 0 10,14,16 * * ?  解释:小时元素用了一个列表,表示每天上午10点,下午2点,4点执行
​
0 0/30 9-17 * * ?   解释:分钟元素用了一个增量,小时元素用了一个连续区间,表示早9点到下午5点每半小时执行一次(9:00、9:30、10:00、......)
​
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-59)例: 14:00:00、14:01:00、14:02:00 ...... 14:59:00
​
"0 0/5 14 * * ?"    解释: 在每天下午2点到下午2:55(因为分钟元素只能取值到59,所以不会到3:00,只能到2:55)期间的每5分钟触发 例:14:00:00、14:05:00、14:10:00、 ...... 、14:55:00
​
"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触发 (L 用在了日期的位置上)
​
"0 15 10 ? * 6L"      解释: 每月的最后一个星期五上午10:15触发 (L用在星期元素上,6表示星期五)
​
"0 15 10 ? * 6L 2002-2005"  解释:2002年至2005年的每月的最后一个星期五上午10:15触发 
​
"0 15 10 ? * 6#3"    解释: 每月的第三个星期五上午10:15触发
​
建议: 为了CRON表达式准确无误,可以用在线工具进行验证

猜你喜欢

转载自blog.csdn.net/m0_65992672/article/details/130421973
今日推荐