1 概述
Quartz
是OpenSymphony
开源组织在Job scheduling
领域又一个开源项目,Quartz
可以用来创建简单或为运行十个,百个,甚至是好几万个Jobs
这样复杂的程序,尽管Quartz
框架整合了许多额外功能,但就其简易形式看,你会发现它易用得简直让人受不了!
2 代码实现
2.1 添加依赖
<!--quartz相关依赖-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-quartz</artifactId>
</dependency>
2.2 继承QuartzJobBean
,实现定时任务
@DisallowConcurrentExecution //禁止任务并行
@Slf4j
public class UploadTask extends QuartzJobBean {
@Override
protected void executeInternal(JobExecutionContext jobExecutionContext){
try {
log.info("任务开始");
TimeUnit.SECONDS.sleep(6);
} catch (InterruptedException e) {
log.info("任务异常");
} finally {
log.info("任务结束");
}
}
}
2.3 Quartz
配置
@Configuration
public class QuartzConfig {
//指定了具体需要执行的类,只不过具体的方法就是我们需要实现的excuteInternal
@Bean
public JobDetail uploadTaskDetail() {
return JobBuilder.newJob(UploadTask.class)
.withIdentity("uploadTask").storeDurably()
.build();
}
//uploadTaskTrigger指定了触发的规则
@Bean
public Trigger uploadTaskTrigger() {
CronScheduleBuilder scheduleBuilder = CronScheduleBuilder.cronSchedule("*/5 * * * * ?");
return TriggerBuilder.newTrigger().forJob(uploadTaskDetail())
.withIdentity("uploadTask")
.withSchedule(scheduleBuilder)
.build();
}
}
3 cron
表达式介绍
顺序 | 秒 | 分钟 | 小时 | 日期 | 月份 | 星期 | 年(可选) |
---|---|---|---|---|---|---|---|
取值 | 0-59 | 0-59 | 0-23 | 1-30(31) | 1-12 | 1-7 | |
允许特殊字符 | , - * / | , - * / | , - * / | , - * / ? L W C | , - * / | , - * / L # C | 1970-2099 , - * / |
*:代表所有可能的值
-:指定范围
,:列出枚举 例如在分钟里,"5,15"表示5分钟和20分钟触发
/:指定增量 例如在分钟里,"3/15"表示从3分钟开始,没隔15分钟执行一次
?:表示没有具体的值,使用?要注意冲突
L:表示last,例如星期中表示7或SAT,月份中表示最后一天31或30,6L表示这个月倒数第6天,FRIL表示这个月的最后一个星期五
W:只能用在日期中,表示最接近指定天的工作日
#:只能用在星期中,表示这个月的第几个周几,例如6#3表示这个月的第3个周五
示例
0 * * * * ? 每1分钟触发一次
0 0 * * * ? 每天每1小时触发一次
0 0 10 * * ? 每天10点触发一次
0 * 14 * * ? 在每天下午2点到下午2:59期间的每1分钟触发
0 30 9 1 * ? 每月1号上午9点半
0 15 10 15 * ? 每月15日上午10:15触发
*/5 * * * * ? 每隔5秒执行一次
0 */1 * * * ? 每隔1分钟执行一次
0 0 5-15 * * ? 每天5-15点整点触发
0 0/3 * * * ? 每三分钟触发一次
0 0 0 1 * ? 每月1号凌晨执行一次
4 测试结果
Quartz
默认线程池大小为10
10个线程串行
读者可以注释掉@DisallowConcurrentExecution
看看运行结果
5 工程目录
6 结束语
说点什么呢,有任何建议,欢迎留言探讨,本文源码。
欢迎关注博主公众号,第一时间推送最新文章