springboot 定时任务 Scheduled(fixedRate ,fixedDelay ,initialDelay,cron)使用
springboot 定时任务
·
一、开启定时任务,加上注解 @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
更多推荐
已为社区贡献3条内容
所有评论(0)