Spring Scheduler里有两个概念:
任务(Task)
运行任务的框架(TaskExecutor/TaskScheduler)
TaskExecutor:任务的执行器,允许我们异步执行多个任务
TaskScheduler:任务调度器,来运行未来的定时任务
触发器(Trigger):决定定时任务是否该运行了,最常用的触发器是CronTrigger
配置(${cron_expression}占位符,配置文件中的值):
Cron举例:
0 * * * * *:每分钟(当秒为0的时候)
0 0 * * * *:每小时(当秒和分都为0的时候)
*/10 * * * * *:每10秒
0 5/15 * * * *:每小时的5分、20分、35分、50分
0 0 9,13 * * *:每天的9点和13点
0 0 8-10 * * *:每天的8点、9点、10点
0 0/30 8-10 * * *:每天的8点、8点半、9点、9点半、10点
0 0 9-17 * * MON-FRI:每周一到周五的9点、10点…直到17点(含)
0 0 0 25 12 ?:每年12约25日圣诞节的0点0分0秒(午夜)
0 30 10 * * ? 2016:2016年每天的10点半
ref实体类:
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
@Component
public class DoSomethingTask {
@Scheduled(cron="0 * * * * *")
public void doSomething() {
System.out.println("do something");
}
}
注意:
不同的task也不能同时运行,原因是scheduler的默认线程数为1
解决1、配置pool-size,这样会导致同一个task前一个还没跑完,后面又被触发的问题
解决2、让任务运行在不同的scheduler里面
TaskExecutor
最初创建TaskExecutor,是为了给其他Spring组件提供一个线程池的抽象