1.在springboot启动类中加入@EnableScheduling注解
2.创建定时任务类添加@Compoment注解
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
import java.util.Date;
@Component
public class ScheduledTask {
@Scheduled(cron = "0/5 * * * * ?")//每5秒执行一次
public void cron(){
System.out.println("时间:"+new Date());
}
}
运行结果
注意:当方法的执行时间超过任务调度频率时,调度器会在下个周期执行
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
import java.util.Arrays;
import java.util.Date;
import java.util.List;
import java.util.concurrent.atomic.AtomicInteger;
@Component
public class ScheduledTask {
private final Logger log = LoggerFactory.getLogger(ScheduledTask.class);
private List<Integer> index = Arrays.asList(8 * 1000, 3 * 1000, 6 * 1000, 2 * 1000, 2 * 1000);
private AtomicInteger atomicInteger = new AtomicInteger(0);
@Scheduled(cron = "0/5 * * * * ?")
public void cron() throws Exception {
//System.out.println("时间:"+new Date());
int i = atomicInteger.get();
if (i < 5) {
Integer sleepTime = index.get(i);
log.info(new Date()+"第{}个任务开始执行,执行时间为{}ms", i, sleepTime);
Thread.sleep(sleepTime);
atomicInteger.getAndIncrement();
}
}
}
每五秒执行一次
第一次任务执行了8秒
第二次任务本应在第 45 秒开始执行,但由于第 40 秒时第一次任务还没执行完,所以第二次任务会把第 5秒这个节点跳过,等到第 10 秒再执行第二次任务
@Scheduled cron表达式
在线Cron表达式生成器:https://qqe2.com/cron
举几个例子:
每隔5秒执行一次:"*/5 * * * * ?"
每隔1分钟执行一次:"0 0/1 * * * ? "
每天23点执行一次:“0 0 23 * * ?”
每天凌晨1点执行一次:“0 0 1 * * ?”
每月1号凌晨1点执行一次:“0 0 1 1 * ?”
每月最后一天23点执行一次:“0 0 23 L * ?”
每周星期天凌晨1点实行一次:“0 0 1 ? * L”
在26分、29分、33分执行一次:“0 26,29,33 * * * ?”
每天的0点、13点、18点、21点都执行一次:“0 0 0,13,18,21 * * ?”
表示在每月的1日的凌晨2点调度任务:“0 0 2 1 * ? *”
表示周一到周五每天上午10:15执行作业:“0 15 10 ? * MON-FRI”
版权声明:本文为Java_fgfg原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。