主要有两种方式。html
Quartz的官网:http://www.quartz-scheduler.org/spring
这两种只是一些配置文件简单配置就OK了,可是根本没法明白其中的内涵所在,在上一篇的 quartz 不一样时间间隔调度任务 有所介绍,能够仔细参考并发
话很少说直接上方案ide
第一步post
以Maven形式添加依赖url
<dependency> <groupId>org.quartz-scheduler</groupId> <artifactId>quartz</artifactId> <version>2.2.3</version> </dependency> <dependency> <groupId>org.quartz-scheduler</groupId> <artifactId>quartz-jobs</artifactId> <version>2.2.3</version> </dependency>
第二步spa
配置xml spring-quartz.xml 线程
你须要将这个配置<import resource="spring-quartz.xml"></import>到你的spring中code
这其中也没啥orm
建立 MethodInvokingJobDetailFactoryBean 基本属性的配置 须要执行的任务类方法
建立 CronTriggerFactoryBean 主要是触发任务的,配置任务触发的时间,能够又多个触发器
建立 SchedulerFactoryBean 调度工厂的做用,你们都把任务放入其中,在其中执行
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd" default-autowire="byType"> <!-- ======================== 任务 Task配置 ======================== --> <!--由MethodInvokingJobDetailFactoryBean实现--> <bean id="WxPayBillTask" class="com.jlnku.task.WxPayBillTask"></bean> <bean id="importOneJob" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean"> <property name="targetObject" ref="WxPayBillTask" /> <!--//执行类的实例--> <property name="targetMethod" value="run" /> <!--//执行方法--> <property name="concurrent" value="false" /> <property name="arguments"> <list></list> </property> </bean> <!-- ======================== 配置定时调度 触发器 ======================== --> <!--由CronTriggerFactoryBean实现--> <bean id="cronTrigger2" class="org.springframework.scheduling.quartz.CronTriggerFactoryBean"> <property name="jobDetail" ref="importOneJob" /> <!-- //上面任务的Task配置bean--> <property name="cronExpression" value="0 02 17 ? * *" /> <!--//触发时机表达式 cron表达式在文章的最末尾会说--> </bean> <!-- ======================== 调度工厂(中心调度器) ======================== --> <bean id="schedulerFactoryBean" class="org.springframework.scheduling.quartz.SchedulerFactoryBean" autowire="no"> <property name="triggers"> <list> <ref bean="cronTrigger2" /> <!--//上面配置的触发器--> </list> </property> </bean> </beans>
第三步
建立你的任务,以线程的形式
其中写你的须要调度的任务逻辑,根据需求编写再次 方法中就ok
/** * @author zhouguanglin * @date 2018/7/5 15:08 */ @Component("WxPayBillTask") public class WxPayBillTask implements Runnable{ @Autowired WXPayService wxPayService; @Override public void run() { try { SimpleDateFormat df = new SimpleDateFormat("yyyyMMdd"); Calendar calendar = Calendar.getInstance(); calendar.setTime(new Date()); calendar.add(Calendar.DATE, -6); String date = df.format(calendar.getTime()); wxPayService.insertWxDownloadBill(null, null, date); } catch (Exception e) { } } }
第一步
加入依赖
<!-- https://mvnrepository.com/artifact/org.quartz-scheduler/quartz --> <dependency> <groupId>org.quartz-scheduler</groupId> <artifactId>quartz</artifactId> <version>2.2.1</version> </dependency>
第二步
在Spring配置开启task任务注解 ,注意你的类也是须要被扫描到的
<!-- task --> <task:annotation-driven />
第三步
本身随便建立一个任务调度的类,内部写和调用本身的逻辑
@Component public class JobDemo { @Autowired WXPayService wxPayService; @Scheduled(cron = "5 * * * * ?") public void FaceBookMessage() { System.out.println("----------------------------任务调度器---------------------------"); } @Scheduled(cron = "0 43 17 ? * *") public void wxPayBillTask(){ try { SimpleDateFormat df = new SimpleDateFormat("yyyyMMdd"); Calendar calendar = Calendar.getInstance(); calendar.setTime(new Date()); calendar.add(Calendar.DATE, -1); String date = df.format(calendar.getTime()); wxPayService.insertWxDownloadBill(null, null, date); } catch (Exception e) { e.printStackTrace(); } } }
这样就完事了
在开始详解每一种Trigger以前,须要先了解一下Trigger的一些共性。
startTime和endTime指定的Trigger会被触发的时间区间。在这个区间以外,Trigger是不会被触发的。
** 全部Trigger都会包含这两个属性 **
当scheduler比较繁忙的时候,可能在同一个时刻,有多个Trigger被触发了,但资源不足(好比线程池不足)。那么这个时候比剪刀石头布更好的方式,就是设置优先级。优先级高的先执行。
须要注意的是,优先级只有在同一时刻执行的Trigger之间才会起做用,若是一个Trigger是9:00,另外一个Trigger是9:30。那么不管后一个优先级多高,前一个都是先执行。
优先级的值默认是5,当为负数时使用默认值。最大值彷佛没有指定,但建议遵循Java的标准,使用1-10,否则鬼才知道看到【优先级为10】是时,上头还有没有更大的值。
相似的Scheduler资源不足的时候,或者机器崩溃重启等,有可能某一些Trigger在应该触发的时间点没有被触发,也就是Miss Fire了。这个时候Trigger须要一个策略来处理这种状况。每种Trigger可选的策略各不相同。
这里有两个点须要重点注意:
全部MisFire的策略实际上都是解答两个问题:
好比SimpleTrigger的MisFire策略有:
MISFIRE_INSTRUCTION_IGNORE_MISFIRE_POLICY
这个不是忽略已经错失的触发的意思,而是说忽略MisFire策略。它会在资源合适的时候,从新触发全部的MisFire任务,而且不会影响现有的调度时间。
好比,SimpleTrigger每15秒执行一次,而中间有5分钟时间它都MisFire了,一共错失了20个,5分钟后,假设资源充足了,而且任务容许并发,它会被一次性触发。
这个属性是全部Trigger都适用。
MISFIRE_INSTRUCTION_FIRE_NOW
忽略已经MisFire的任务,而且当即执行调度。这一般只适用于只执行一次的任务。
MISFIRE_INSTRUCTION_RESCHEDULE_NOW_WITH_EXISTING_REPEAT_COUNT
将startTime设置当前时间,当即从新调度任务,包括的MisFire的
MISFIRE_INSTRUCTION_RESCHEDULE_NOW_WITH_REMAINING_REPEAT_COUNT
相似MISFIRE_INSTRUCTION_RESCHEDULE_NOW_WITH_EXISTING_REPEAT_COUNT,区别在于会忽略已经MisFire的任务
MISFIRE_INSTRUCTION_RESCHEDULE_NEXT_WITH_EXISTING_COUNT
在下一次调度时间点,从新开始调度任务,包括的MisFire的
MISFIRE_INSTRUCTION_RESCHEDULE_NEXT_WITH_REMAINING_COUNT
相似于MISFIRE_INSTRUCTION_RESCHEDULE_NEXT_WITH_EXISTING_COUNT,区别在于会忽略已经MisFire的任务。
MISFIRE_INSTRUCTION_SMART_POLICY
全部的Trigger的MisFire默认值都是这个,大体意思是“把处理逻辑交给聪明的Quartz去决定”。基本策略是,
位置 | 时间域 | 容许值 | 特殊值 |
---|---|---|---|
1 | 秒 | 0-59 | , - * / |
2 | 分钟 | 0-59 | , - * / |
3 | 小时 | 0-23 | , - * / |
4 | 日期 | 1-31 | , - * ? / L W C |
5 | 月份 | 1-12 | , - * / |
6 | 星期 | 1-7 | , - * ? / L C # |
7 | 年份(可选) | 1-31 | , - * / |
星号():可用在全部字段中,表示对应时间域的每个时刻,例如, 在分钟字段时,表示“每分钟”;
问号(?):该字符只在日期和星期字段中使用,它一般指定为“无心义的值”,至关于点位符;
减号(-):表达一个范围,如在小时字段中使用“10-12”,则表示从10到12点,即10,11,12;
逗号(,):表达一个列表值,如在星期字段中使用“MON,WED,FRI”,则表示星期一,星期三和星期五;
斜杠(/):x/y表达一个等步长序列,x为起始值,y为增量步长值。如在分钟字段中使用0/15,则表示为0,15,30和45秒,而5/15在分钟字段中表示5,20,35,50,你也可使用*/y,它等同于0/y;
L:该字符只在日期和星期字段中使用,表明“Last”的意思,但它在两个字段中意思不一样。L在日期字段中,表示这个月份的最后一天,如一月的31号,非闰年二月的28号;若是L用在星期中,则表示星期六,等同于7。可是,若是L出如今星期字段里,并且在前面有一个数值X,则表示“这个月的最后X天”,例如,6L表示该月的最后星期五;
W:该字符只能出如今日期字段里,是对前导日期的修饰,表示离该日期最近的工做日。例如15W表示离该月15号最近的工做日,若是该月15号是星期六,则匹配14号星期五;若是15日是星期日,则匹配16号星期一;若是15号是星期二,那结果就是15号星期二。但必须注意关联的匹配日期不可以跨月,如你指定1W,若是1号是星期六,结果匹配的是3号星期一,而非上个月最后的那天。W字符串只能指定单一日期,而不能指定日期范围;
LW组合:在日期字段能够组合使用LW,它的意思是当月的最后一个工做日;
井号(#):该字符只能在星期字段中使用,表示当月某个工做日。如6#3表示当月的第三个星期五(6表示星期五,#3表示当前的第三个),而4#5表示当月的第五个星期三,假设当月没有第五个星期三,忽略不触发;
C:该字符只在日期和星期字段中使用,表明“Calendar”的意思。它的意思是计划所关联的日期,若是日期没有被关联,则至关于日历中全部日期。例如5C在日期字段中就至关于日历5日之后的第一天。1C在星期字段中至关于星期往后的第一天。
Cron表达式对特殊字符的大小写不敏感,对表明星期的缩写英文大小写也不敏感。
一些例子:
表示式 | 说明 |
---|---|
0 0 12 * * ? | 天天12点运行 |
0 15 10 ? * * | 天天10:15运行 |
0 15 10 * * ? | 天天10:15运行 |
0 15 10 * * ? * | 天天10:15运行 |
0 15 10 * * ? 2008 | 在2008年的天天10:15运行 |
0 * 14 * * ? | 天天14点到15点之间每分钟运行一次,开始于14:00,结束于14:59。 |
0 0/5 14 * * ? | 天天14点到15点每5分钟运行一次,开始于14:00,结束于14:55。 |
0 0/5 14,18 * * ? | 天天14点到15点每5分钟运行一次,此外天天18点到19点每5钟也运行一次。 |
0 0-5 14 * * ? | 天天14:00点到14:05,每分钟运行一次。 |
0 10,44 14 ? 3 WED | 3月每周三的14:10分到14:44,每分钟运行一次。 |
0 15 10 ? * MON-FRI | 每周一,二,三,四,五的10:15分运行。 |
0 15 10 15 * ? | 每个月15日10:15分运行。 |
0 15 10 L * ? | 每个月最后一天10:15分运行。 |
0 15 10 ? * 6L | 每个月最后一个星期五10:15分运行。 |
0 15 10 ? * 6L 2007-2009 | 在2007,2008,2009年每月的最后一个星期五的10:15分运行。 |
0 15 10 ? * 6#3 | 每个月第三个星期五的10:15分运行。 |
【版本声明】本文为博主原创文章,转载请注明出处