**使用quartz第一步先导入依赖**
<dependency>
<groupId>org.quartz-scheduler</groupId>
<artifactId>quartz</artifactId>
<version>2.3.2</version>
<exclusions>
<exclusion>
<artifactId>slf4j-api</artifactId>
<groupId>org.slf4j</groupId>
</exclusion>
</exclusions>
</dependency>
第二步,编写实现了Job接口的实现类,该类中编写我们的任务,就是要做的事
public class QuartzJob implements Job {
@Override
public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException {
System.out.println("每天凌晨一点起来上厕所");
}
}
接下来就是编写配置类
QuartzConfig类来绑定调用的方法和触发的关系
这个触发实际上会由Spring容器中的Scheduler对象调度
@Configuration
public class QuartzConfig {
// Quartz任务调度生效条件是将JobDetail和Trigger对象保存到Spring容器中
// JobDetail对象封装任务内容,Trigger对象封装触发时机
// 利用@Bean注解,将JobDetail和Trigger对象保存到Spring容器中
@Bean
public JobDetail quartzwork(){
// JobDetail对象中配置时要将欲触发的Job接口实现类配置在框架指定的方法中
// JobBuilder.newJob方法是可以创建JobDetail对象的,方法参数就是Job接口实现类的反射即可
return JobBuilder.newJob(QuartzJob.class)
// 需要给当前任务起名,不要和其他任务重名
.withIdentity("search")
// 默认情况下JobDetail生成后,如果没有触发器绑定会自动移除
// 设置storeDurably()方法后,JobDetail生成后即使没有被绑定,也不会被移除了
.storeDurably()
.build();
}
// 下面开始编写触发器的配置,目标是绑定上面JobDetail,实现在指定时间触发
@Bean
public Trigger showTimeTrigger(){
// 声明Cron表达式,定义触发时间
CronScheduleBuilder cron=
CronScheduleBuilder.cronSchedule("0 0 1 * * ?");//每天凌晨一点
return TriggerBuilder.newTrigger()
// 绑定要运行的JobDetail对象
.forJob(quartzSearch())
// 当前触发器也要起名字,名字也不要重复
.withIdentity("quartzSearch")
// 绑定cron表达式
.withSchedule(cron)
.build();
}
}
关于cron表达式
cron表达式是由七个子表达式组成。这些表达式之间用空格分隔。
如下:
Seconds (秒) 范围: (0~59)
Minutes(分) 范围:(0~59)
Hours(小时) 范围: (0~23)
Day-of-Month (天) 范围: (1~31,不是所有月都是31天)
Month(月) 范围:(0~11,或者"JAN, FEB, MAR, APR, MAY, JUN, JUL, AUG, SEP, OCT, NOV,DEC")
Day-of-Week (周) 范围: (1~7,1=SUN 或者"SUN, MON, TUE, WED, THU, FRI, SAT”)
Year(年) 范围:(1970~2099)
个别子表达式可以包含范围或者列表
子表达式的格式如下:
字段名 | 允许的值 | 允许的特殊字符 |
秒 | 0-59 | , - * / |
分 | 0-59 | , - * / |
小时 | 0-23 | , - * / |
日 | 1-31 | , - * ? / L W C |
月 | 1-12 or JAN-DEC | , - * / |
周 | 1-7 or SUN-SAT | , - * ? / L C # |
年(可选字段) | empty | 1970-2099 , - * / |
字符含义:
* :代表所有可能的值。因此,“*”在Month中表示每个月,在Day-of-Month中表示每天,在Hours表示每小时
- :表示指定范围。
, :表示列出枚举值。例如:在Minutes子表达式中,“5,20”表示在5分钟和20分钟触发。
/ :被用于指定增量。例如:在Minutes子表达式中,“0/15”表示从0分钟开始,每15分钟执行一次。"3/20"表示从第三分钟开始,每20分钟执行一次。和"3,23,43"(表示第3,23,43分钟触发)的含义一样。
? :用在Day-of-Month和Day-of-Week中,指“没有具体的值”。当两个子表达式其中一个被指定了值以后,为了避免冲突,需要将另外一个的值设为“?”。例如:想在每月20日触发调度,不管20号是星期几,只能用如下写法:0 0 0 20 * ?,其中最后以为只能用“?”,而不能用“*”。
L :用在day-of-month和day-of-week字串中。它是单词“last”的缩写。它在两个子表达式中的含义是不同的。
在day-of-month中,“L”表示一个月的最后一天,一月31号,3月30号。
在day-of-week中,“L”表示一个星期的最后一天,也就是“7”或者“SAT”
如果“L”前有具体内容,它就有其他的含义了。例如:“6L”表示这个月的倒数第六天。“FRIL”表示这个月的最后一个星期五。
注意:在使用“L”参数时,不要指定列表或者范围,这样会出现问题。
W :“Weekday”的缩写。只能用在day-of-month字段。用来描叙最接近指定天的工作日(周一到周五)。例如:在day-of-month字段用“15W”指“最接近这个月第15天的工作日”,即如果这个月第15天是周六,那么触发器将会在这个月第14天即周五触发;如果这个月第15天是周日,那么触发器将会在这个月第 16天即周一触发;如果这个月第15天是周二,那么就在触发器这天触发。注意一点:这个用法只会在当前月计算值,不会越过当前月。“W”字符仅能在 day-of-month指明一天,不能是一个范围或列表。也可以用“LW”来指定这个月的最后一个工作日,即最后一个星期五。
# :只能用在day-of-week字段。用来指定这个月的第几个周几。例:在day-of-week字段用"6#3" or "FRI#3"指这个月第3个周五(6指周五,3指第3个)。如果指定的日期不存在,触发器就不会触发。