SpringBoot集成定时任务,整合Scheduled(一)
本次将对Scheduled进行整合
项目环境
- IDEA 2019.1
- SpringBoot 2.1.5
- Gradle 4.10
整合步骤
@Scheduled
SpringBoot内置了定时任务Scheduled,能够很好的实现定时任务。
- 在SpringBoot应用添加
@EnableScheduling
注解启动定时任务
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.scheduling.annotation.EnableScheduling;
@SpringBootApplication
@EnableScheduling
public class FastSpringbootApplication {
public static void main(String[] args) {
SpringApplication.run(FastSpringbootApplication.class, args);
}
}
- 添加测试定时任务的代码。
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
@Component
public class ScheduledTask {
@Scheduled(cron = "5 0 0 * * ?")
public void scheduledTask1(){
System.out.println("定时任务1");
}
@Scheduled(initialDelay = 1000 * 10,fixedDelay = 1000 * 5)
public void scheduledTask2(){
System.out.println("任务2执行时间:"+System.currentTimeMillis());
System.out.println("定时任务2");
try {
Thread.sleep(2*1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("任务2结束时间:"+System.currentTimeMillis());
}
@Scheduled(initialDelay = 1000 * 10,fixedRate = 1000 * 5)
public void scheduledTask3(){
System.out.println("任务3执行时间:"+System.currentTimeMillis());
System.out.println("定时任务3");
try {
Thread.sleep(2*1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("任务3结束时间:"+System.currentTimeMillis());
}
}
- corn表达式在linux使用广泛,具体可以参考cron表达式详解以及在线Cron表达式生成器
- initialDelay:启动后多久开始执行,单位时毫秒
- fixedRate:下次执行时间,任务开始运行的时候就计时。
- fixedDelay:下次执行时间,fixedDelay等任务进行完了才开始计时
关于fixedRate和fixedDelay的运行效果接下来详述,下面时运行一段时间的效果:
任务3执行时间:1558876357313
定时任务3
任务3结束时间:1558876359313
任务2执行时间:1558876359313
定时任务2
任务2结束时间:1558876361314
任务3执行时间:1558876362312
定时任务3
任务3结束时间:1558876364313
任务2执行时间:1558876366316
定时任务2
任务2结束时间:1558876368316
任务3执行时间:1558876368316
定时任务3
任务3结束时间:1558876370316
任务3执行时间:1558876372313
定时任务3
任务3结束时间:1558876374314
任务2执行时间:1558876374314
定时任务2
任务2结束时间:1558876376314
- 任务3和任务2的第一次执行时间都是启动10S后开始执行,时间是
1558876357313
。 - 任务三fixedRate第一次开始时间
1558876357313
结束时间1558876359313
中间间隔2S
。任务三第二次执行时间1558876362312
结束时间1558876364313
。1558876362312(第二次开始时间)-1558876357313(第一次开始时间)=4999,等于5S。 - 任务二fixedDelay第一次开始时间
1558876359313
,第一次结束时间1558876361314
。第二次开始时间1558876366316
,结束时间1558876368316
。
1558876366316(第二次开始时间) – 1558876361314(第一次结束时间) = 5002排除唤醒任务的细微时间,等于5S
通过以上的示例,更容易理解。
项目代码
- github:点击这里
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/13168.html