springboot 定时任务 Scheduled(fixedRate ,fixedDelay ,initialDelay,cron)使用

一、开启定时任务,加上注解 @EnableScheduling即可

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

二、编写定时任务,在需要定时处理的方法上加 @Scheduled注解

@Component
public class TestScheduled {
	//3s一次
    @Scheduled(fixedRate = 3000)
    public void timeJob(){
        System.out.println("任务开始时间-->"+ LocalDateTime.now());
        try {
            System.out.println("定时任务处理中。。。。。");
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("任务结束时间-->"+ LocalDateTime.now());
    }
}

三、启动运行即可
可以看到每次的时间是从上一次任务开始时间 + 3s

任务开始时间-->2022-03-18T10:59:13.643  //3s后开始下次任务
定时任务处理中。。。。。
任务结束时间-->2022-03-18T10:59:14.652

任务开始时间-->2022-03-18T10:59:16.632
定时任务处理中。。。。。
任务结束时间-->2022-03-18T10:59:17.647

以上,即可!

四、参数说明

@Scheduled(fixedRate = 3000) 上一次开始执行时间点之后3秒再执行

此处如果处理时间超过3s,会怎么样?

改为Thread.sleep(4000),如下图 可以看到,任务执行了4秒,下一个定时任务是一直在阻塞,直到上一个任务结束才开始。

任务开始时间-->2022-03-18T11:29:59.280 //4s后开始下次任务
定时任务处理中。。。。。
任务结束时间-->2022-03-18T11:30:03.282
    
任务开始时间-->2022-03-18T11:30:03.282
定时任务处理中。。。。。
任务结束时间-->2022-03-18T11:30:07.287

@Scheduled(fixedDelay = 3000) 上一次执行结束时间点之后3秒再执行

运行如下

任务开始时间-->2022-03-18T11:37:37.326
定时任务处理中。。。。。
任务结束时间-->2022-03-18T11:37:38.337  //3s后开始下次任务
    
任务开始时间-->2022-03-18T11:37:41.343
定时任务处理中。。。。。
任务结束时间-->2022-03-18T11:37:42.354

@Scheduled(initialDelay=3000, fixedRate=3000) :第一次延迟1秒后执行,之后按fixedRate的规则每3秒执行一次

@Scheduled(initialDelay = 10000 ,fixedRate = 3000)
public void timeJob(){
    System.out.println("任务开始时间-->"+ LocalDateTime.now());
    try {
        System.out.println("定时任务处理中。。。。。");
        Thread.sleep(1000);
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
    System.out.println("任务结束时间-->"+ LocalDateTime.now());
}

在这里插入图片描述

@Scheduled(cron = “0/3 * * * * ?”) //通过表达式 类似fixedRate

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

音乐土豆

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值