<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-quartz</artifactId>
</dependency>
主要用springboot的@Scheduled注解进行定时任务的布置,该注解的两个重要属性:
fixedDelay
它的间隔时间是根据上次的任务结束的时候开始计时的。比如一个方法上设置了fixedDelay=5*1000,那么当该方法某一次执行结束后,开始计算时间,当时间达到5秒,就开始再次执行该方法。
fixedRate
它的间隔时间是根据上次任务开始的时候计时的。比如当方法上设置了fiexdRate=51000,该执行该方法所花的时间是2秒,那么3秒后就会再次执行该方法。
但是这里有个坑,当任务执行时长超过设置的间隔时长,那会是什么结果呢。打个比方,比如一个任务本来只需要花2秒就能执行完成,我所设置的fixedRate=51000,但是因为网络问题导致这个任务花了7秒才执行完成。当任务开始时Spring就会给这个任务计时,5秒钟时候Spring就会再次调用这个任务,可是发现原来的任务还在执行,这个时候第二个任务就阻塞了(这里只考虑单线程的情况下,多线程后面再讲),甚至如果第一个任务花费的时间过长,还可能会使第三第四个任务被阻塞。被阻塞的任务就像排队的人一样,一旦前一个任务没了,它就立马执行。
另一个属性是cron
他有自己的表达式规律,举例如下:
每天18点15分执行:0 15 18 * * ?
每月 一 号5点执行 :0 0 5 1 * ?
每天10点28分执行:0 28 10 * * ?
新建一个定时任务的Job类
package com.clj.timeTest;
import java.util.Date;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
@Component
public class Jobs {
public final static long sixSeconds = 60 * 100;
@Scheduled(fixedDelay=sixSeconds)//
public void fixedDelayJob(){
System.out.println("---------"+new Date()+"fixedDelay执行....");
}
@Scheduled(fixedRate=sixSeconds)
public void fixedRateJob(){
System.out.println("---------"+new Date()+"fixedRate执行....");
}
@Scheduled(cron="0 28 10 * * ?")
public void cronJob(){
System.out.println("---------"+new Date()+"cronJob执行....");
}
}
启动类:
package com.clj.timeTest;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.boot.web.servlet.support.SpringBootServletInitializer;
import org.springframework.scheduling.annotation.EnableScheduling;
@SpringBootApplication
@EnableScheduling
public class TimeTestApplication extends SpringBootServletInitializer{
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
return builder.sources(TimeTestApplication.class);
}
public static void main(String[] args) {
SpringApplication.run(TimeTestApplication.class, args);
}
}
执行结果如下: