一、开启定时任务,加上注解 @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

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐