Quartz是一个强大任务调度框架,我工做时候会在这些状况下使用到quartz框架,固然还有不少的应用场景,在这里只列举2个实际用到的java
人事系统会在天天早晨8点给有待办的人员自动发送Email提醒数据库
使用quartz,咱们仅仅须要在maven的pom文件中添加依赖便可。我使用的是如今最新的一个版本2.3.0,你们能够在maven的仓库获取到最新的版本依赖,地址:http://mvnrepository.com/artifact/org.quartz-scheduler/quartz并发
但然也可使用这个2.3.0的依赖,下面的例子都是使用此依赖并实现了效果。框架
<!-- https://mvnrepository.com/artifact/org.quartz-scheduler/quartz --> <dependency> <groupId>org.quartz-scheduler</groupId> <artifactId>quartz</artifactId> <version>2.3.0</version> </dependency>
先实现一下这个基本的Quartz的任务再来介绍一下Quartz的3个重要组成,JobDetail,Trigger,Schedulermaven
import org.quartz.Job;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class HelloJob implements Job{ public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException { //打印当前的执行时间 例如 2017-11-23 00:00:00 Date date = new Date(); SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); System.out.println("如今的时间是:"+ sf.format(date)); //具体的业务逻辑 System.out.println("Hello Quartz"); } }
public class HelloScheduler { public static void main(String[] args) throws SchedulerException { //建立一个jobDetail的实例,将该实例与HelloJob Class绑定 JobDetail jobDetail = JobBuilder.newJob(HelloJob.class).withIdentity("myJob").build(); //建立一个Trigger触发器的实例,定义该job当即执行,而且每2秒执行一次,一直执行 SimpleTrigger trigger = TriggerBuilder.newTrigger().withIdentity("myTrigger").startNow().withSchedule(SimpleScheduleBuilder.simpleSchedule().withIntervalInSeconds(2).repeatForever()).build(); //建立schedule实例 StdSchedulerFactory factory = new StdSchedulerFactory(); Scheduler scheduler = factory.getScheduler(); scheduler.start(); scheduler.scheduleJob(jobDetail,trigger); } }
一、建立调度工厂(); //工厂模式函数
与上一个的简单案例的区别在于,SimpleTrigger/CronTrigger. 简单的定时任务,能够采用SimpleTrigger,复杂的任务通常采用CronTrigger.cronTrigger不只能够设定单的触发时间表,更能够设定很是复杂的触发时间表。 CronTrigger 是基于 Unix相似于 cron 表达式,若是对cron表达式比较熟悉,那么学习起来经很是简单. 即便对cron表达式不熟悉,花一下子的功夫也能够学会。(在工做中咱们直接使用网上的在线生成表达式便可又快又准确)生成地址:http://cron.qqe2.com/学习
先上代码,而后介绍一下cron表达式生成规则。ui
public class HelloJob implements Job{ public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException { //打印当前的执行时间 例如 2017-11-22 00:00:00 Date date = new Date(); SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); System.out.println("如今的时间是:"+ sf.format(date)); //具体的业务逻辑 System.out.println("开始生成任务报表 或 开始发送邮件"); } }
public class CronScheduler { public static void main(String[] args) throws SchedulerException, InterruptedException { //jobDetail JobDetail jobDetail = JobBuilder.newJob(HelloJob.class).withIdentity("cronJob").build(); //cronTrigger //每日的9点40触发任务 CronTrigger cronTrigger = TriggerBuilder.newTrigger().withIdentity("cronTrigger").withSchedule(CronScheduleBuilder.cronSchedule("0 40 9 * * ? ")).build(); //1.每日10点15分触发 0 15 10 ?* * //2.天天下午的2点到2点59分(正点开始,隔5分触发) 0 0/5 14 * * ? //3.从周一到周五天天的上午10点15触发 0 15 10 ? MON-FRI //4.每个月的第三周的星期五上午10点15触发 0 15 10 ? * 6#3 //5.2016到2017年每个月最后一周的星期五的10点15分触发 0 15 10 ? * 6L 2016-2017 //Scheduler实例 StdSchedulerFactory stdSchedulerFactory = new StdSchedulerFactory(); Scheduler scheduler = stdSchedulerFactory.getScheduler(); scheduler.start(); scheduler.scheduleJob(jobDetail,cronTrigger); } }
名称 | 是否必须 | 容许值 | 特殊字符 |
---|---|---|---|
秒 | 是 | 0-59 | , - * / |
分 | 是 | 0-59 | , - * / |
时 | 是 | 0-23 | , - * / |
日 | 是 | 1-31 | , - * ? / L W C |
月 | 是 | 1-12 或 JAN-DEC | , - * / |
周 | 是 | 1-7 或 SUN-SAT | , - * ? / L C # |
年 | 否 | 空 或 1970-2099 | , - * / |
注意在cron表达式中不区分大小写.this
星号(*):可用在全部字段中,表示对应时间域的每个时刻,例如, 在分钟字段时,表示“每分钟”;spa
问号(?):该字符只在日期和星期字段中使用,它一般指定为“无心义的值”,至关于点位符;
减号(-):表达一个范围,如在小时字段中使用“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表达式对特殊字符的大小写不敏感,对表明星期的缩写英文大小写也不敏感。
2.官方的一些案例
表示式 | 说明 |
---|---|
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分运行。 |
以上就能够实现大部分的业务的需求了,如下是对Quartz的API的一些了解
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
Quartz对任务调度的领域问题进行了高度的抽象,提出了调度器、任务和触发器这3个核心的概念,并在org.quartz经过接口和类对重要的这些核心概念进行描述:
●Job:是一个接口,只有一个方法void execute(JobExecutionContext context),开发者实现该接口定义运行任务,JobExecutionContext类提供了调度上下文的各类信息。Job运行时的信息保存在JobDataMap实例中;
●JobDetail:Quartz在每次执行Job时,都从新建立一个Job实例,因此它不直接接受一个Job的实例,相反它接收一个Job实现类,以便运行时经过newInstance()的反射机制实例化Job。所以须要经过一个类来描述Job的实现类及其它相关的静态信息,如Job名字、描述、关联监听器等信息,JobDetail承担了这一角色。
经过该类的构造函数能够更具体地了解它的功用:JobDetail(java.lang.String name, java.lang.String group, java.lang.Class jobClass),该构造函数要求指定Job的实现类,以及任务在Scheduler中的组名和Job名称;
●Trigger:是一个类,描述触发Job执行的时间触发规则。主要有SimpleTrigger和CronTrigger这两个子类。当仅需触发一次或者以固定时间间隔周期执行,SimpleTrigger是最适合的选择;而CronTrigger则能够经过Cron表达式定义出各类复杂时间规则的调度方案:如每早晨9:00执行,周1、周3、周五下午5:00执行等;
●Calendar:org.quartz.Calendar和java.util.Calendar不一样,它是一些日历特定时间点的集合(能够简单地将org.quartz.Calendar看做java.util.Calendar的集合——java.util.Calendar表明一个日历时间点,无特殊说明后面的Calendar即指org.quartz.Calendar)。一个Trigger能够和多个Calendar关联,以便排除或包含某些时间点。
假设,咱们安排每周星期一早上10:00执行任务,可是若是碰到法定的节日,任务则不执行,这时就须要在Trigger触发机制的基础上使用Calendar进行定点排除。针对不一样时间段类型,Quartz在org.quartz.impl.calendar包下提供了若干个Calendar的实现类,如AnnualCalendar、MonthlyCalendar、WeeklyCalendar分别针对每一年、每个月和每周进行定义;
●Scheduler:表明一个Quartz的独立运行容器,Trigger和JobDetail能够注册到Scheduler中,二者在Scheduler中拥有各自的组及名称,组及名称是Scheduler查找定位容器中某一对象的依据,Trigger的组及名称必须惟一,JobDetail的组和名称也必须惟一(但能够和Trigger的组和名称相同,由于它们是不一样类型的)。Scheduler定义了多个接口方法,容许外部经过组及名称访问和控制容器中Trigger和JobDetail。
Scheduler能够将Trigger绑定到某一JobDetail中,这样当Trigger触发时,对应的Job就被执行。一个Job能够对应多个Trigger,但一个Trigger只能对应一个Job。能够经过SchedulerFactory建立一个Scheduler实例。Scheduler拥有一个SchedulerContext,它相似于ServletContext,保存着Scheduler上下文信息,Job和Trigger均可以访问SchedulerContext内的信息。SchedulerContext内部经过一个Map,以键值对的方式维护这些上下文数据,SchedulerContext为保存和获取数据提供了多个put()和getXxx()的方法。能够经过Scheduler# getContext()获取对应的SchedulerContext实例;
●ThreadPool:Scheduler使用一个线程池做为任务运行的基础设施,任务经过共享线程池中的线程提升运行效率。
Job有一个StatefulJob子接口,表明有状态的任务,该接口是一个没有方法的标签接口,其目的是让Quartz知道任务的类型,以便采用不一样的执行方案。无状态任务在执行时拥有本身的JobDataMap拷贝,对JobDataMap的更改不会影响下次的执行。而有状态任务共享共享同一个JobDataMap实例,每次任务执行对JobDataMap所作的更改会保存下来,后面的执行能够看到这个更改,也即每次执行任务后都会对后面的执行发生影响。
正由于这个缘由,无状态的Job能够并发执行,而有状态的StatefulJob不能并发执行,这意味着若是前次的StatefulJob尚未执行完毕,下一次的任务将阻塞等待,直到前次任务执行完毕。有状态任务比无状态任务须要考虑更多的因素,程序每每拥有更高的复杂度,所以除非必要,应该尽可能使用无状态的Job。
若是Quartz使用了数据库持久化任务调度信息,无状态的JobDataMap仅会在Scheduler注册任务时保持一次,而有状态任务对应的JobDataMap在每次执行任务后都会进行保存。
Trigger自身也能够拥有一个JobDataMap,其关联的Job能够经过JobExecutionContext#getTrigger().getJobDataMap()获取Trigger中的JobDataMap。无论是有状态仍是无状态的任务,在任务执行期间对Trigger的JobDataMap所作的更改都不会进行持久,也即不会对下次的执行产生影响。
Quartz拥有完善的事件和监听体系,大部分组件都拥有事件,如任务执行前事件、任务执行后事件、触发器触发前事件、触发后事件、调度器开始事件、关闭事件等等,能够注册相应的监听器处理感兴趣的事件。
JobDetail是任务的定义,而Job是任务的执行逻辑。在JobDetail里会引用一个Job Class定义。
每个JobDetail都会有一个JobDataMap。JobDataMap本质就是一个Map的扩展类,只是提供了一些更便捷的方法,好比getString()之类的。
仍是老样子,编写两个类来看效果。
public class HelloScheduler { public static void main(String[] args) throws SchedulerException { //1.建立一个jobDetail的实例,将该实例与HelloJob Class绑定 JobDetail jobDetail = JobBuilder .newJob(HelloJob.class) //定义Job类为HelloJob类,真正的执行逻辑所在 .withIdentity("myJob", "group1") //定义name 和 group .usingJobData("message","hello myJob1") //加入属性到jobDataMap .usingJobData("FloatJobValue",8.88f) //加入属性到jobDataMap .build(); //2.建立一个Trigger触发器的实例,定义该job当即执行,而且每2秒执行一次,一直执行 SimpleTrigger trigger = TriggerBuilder.newTrigger() .withIdentity("myTrigger", "group1") .startNow() .withSchedule(SimpleScheduleBuilder.simpleSchedule().withIntervalInSeconds(2).repeatForever()) .build(); //3.建立schedule实例 StdSchedulerFactory factory = new StdSchedulerFactory(); Scheduler scheduler = factory.getScheduler(); scheduler.start(); //启动 scheduler.scheduleJob(jobDetail,trigger); // jobDetail和trigger加入调度 } }
public class HelloJob implements Job{ public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException { //打印当前的执行时间 例如 2017-11-22 00:00:00 Date date = new Date(); SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); System.out.println("如今的时间是:"+ sf.format(date)); //具体的业务逻辑 System.out.println("开始生成任务报表 或 开始发送邮件...."); JobKey key = jobExecutionContext.getJobDetail().getKey(); System.out.println("jobDetail 的name : "+key.getName()); //打印jobDetail 的name System.out.println("jobDetail 的group : "+key.getGroup()); //打印jobDetail 的group JobDataMap jobDetailDataMap = jobExecutionContext.getJobDetail().getJobDataMap(); String message = jobDetailDataMap.getString("message"); // float floatJobValue = jobDetailDataMap.getFloat("FloatJobValue"); System.out.println("jobDataMap定义的message的值 : "+message ); //打印jobDataMap定义的message的值 System.out.println("jobDataMap定义的floatJobValue的值 : "+floatJobValue ); //jobDataMap定义的floatJobValue的值 } }
public class HelloJob implements Job{ //这里是第二种获取jobDataMap中的值的方法 private String message; private Float floatJobValue; private Double doubleTriggerValue; public String getMessage() { return message; } public void setMessage(String message) { this.message = message; } public Float getFloatJobValue() { return floatJobValue; } public void setFloatJobValue(Float floatJobValue) { this.floatJobValue = floatJobValue; } public Double getDoubleTriggerValue() { return doubleTriggerValue; } public void setDoubleTriggerValue(Double doubleTriggerValue) { this.doubleTriggerValue = doubleTriggerValue; } public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException { //打印当前的执行时间 例如 2017-11-22 00:00:00 Date date = new Date(); SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); System.out.println("如今的时间是:"+ sf.format(date)); System.out.println("jobDataMap定义的message的值 : "+message ); //打印jobDataMap定义的message的值 System.out.println("jobDataMap定义的floatJobValue的值 : "+floatJobValue ); //jobDataMap定义的floatJobValue的值 } }
有时候咱们但愿一个定时任务在必定的时间内是天天执行,好比2017年11月24日到2017年12月15日之间执行,这时候咱们就要使用startTime和endTime来限定事件范围了。例子中咱们把时间规定在几秒钟以内运行,方便查看效果。
public class SecondScheduler { public static void main(String[] args) throws SchedulerException { //建立一个JobDetail的实例,将该实例与HelloJob绑定 JobDetail jobDetail = JobBuilder.newJob(HelloJob.class).withIdentity("zhlJob").build(); //开始时间 3秒钟以后 (具体时间按实际业务编写) Date sData = new Date(); sData.setTime(sData.getTime()+3000); //结束时间 6秒钟以后 (具体时间按实际业务编写) Date eData = new Date(); eData.setTime(eData.getTime()+6000); //建立一个Trigger实例,定义该job3秒以后执行,在6秒以后结束 SimpleTrigger zhlTrigger = TriggerBuilder.newTrigger().withIdentity("zhlTrigger") .startAt(sData) //设定开始时间 .endAt(eData) //设定结束时间 .withSchedule(SimpleScheduleBuilder.simpleSchedule().withIntervalInSeconds(2).repeatForever()) //每两秒打印一次 .build(); //建立Scheduler实例 StdSchedulerFactory stdSchedulerFactory = new StdSchedulerFactory(); Scheduler scheduler = stdSchedulerFactory.getScheduler(); scheduler.start(); scheduler.scheduleJob(jobDetail,zhlTrigger); } }
public class HelloJob implements Job{public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException { //打印当前的执行时间 例如 2017-11-22 00:00:00 Date date = new Date(); SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); System.out.println("如今的时间是:"+ sf.format(date)); //具体的业务逻辑 System.out.println("具体执行的业务..."); JobKey key = jobExecutionContext.getJobDetail().getKey(); Trigger trigger = jobExecutionContext.getTrigger(); System.out.println("开始的时间: "+sf.format(trigger.getStartTime())); //打印开始时间 System.out.println("结束的事件: "+sf.format(trigger.getEndTime())); //打印结束时间 } }
此calendar不是java.util.Calendar,calendar是为了补充Trigger的时间,能够拍除了或加入一下特定的时间。Quartz 的 Calender 专门用于屏闭一个时间区间,使 Trigger 在这个区间中不被触发。
下面以AnnualCalendar举例,来实现某一天不执行程序。
public class CalendarSchedule { public static void main(String[] args) throws SchedulerException { SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); //建立一个JobDetail的实例,将该实例与HelloJob绑定 JobDetail jobDetail = JobBuilder.newJob(HelloJob.class).withIdentity("zhlJob").build(); AnnualCalendar holidays = new AnnualCalendar(); GregorianCalendar nationalDay = new GregorianCalendar(2017, 10, 27); // 排除今天的时间2017年11月27日(月份是从0~11的) holidays.setDayExcluded(nationalDay,true); //排除的日期,若是为false则为包含*/ //建立Scheduler实例 StdSchedulerFactory stdSchedulerFactory = new StdSchedulerFactory(); Scheduler scheduler = stdSchedulerFactory.getScheduler(); //向Scheduler注册日历 scheduler.addCalendar("holidays",holidays,false,false); Trigger simpleTrigger = TriggerBuilder.newTrigger() .withIdentity("zhlTrigger") .withSchedule(SimpleScheduleBuilder.simpleSchedule().withIntervalInSeconds(1).repeatForever()) //每一秒执行一次job .modifiedByCalendar("holidays") //将咱们设置好的Calander与trigger绑定 .build(); //让trigger应用指定的日历规则 //scheduler.scheduleJob(jobDetail,simpleTrigger); System.out.println("如今的时间 :"+sf.format(new Date())); System.out.println("最近的一次执行时间 :"+sf.format(scheduler.scheduleJob(jobDetail,simpleTrigger))); //scheduler与jobDetail、trigger绑定,并打印出最近一次执行的事件 scheduler.start(); } }
public class HelloJob implements Job{public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException { //打印当前的执行时间 例如 2017-11-22 00:00:00 Date date = new Date(); SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); System.out.println("如今的时间是:"+ sf.format(date)); //具体的业务逻辑 System.out.println("具体执行的业务..."); Trigger trigger = jobExecutionContext.getTrigger(); System.out.println("开始的时间: "+sf.format(trigger.getStartTime())); //打印开始时间 System.out.println("结束的事件: "+sf.format(trigger.getEndTime())); //打印结束时间 }
能够发现,我将程序设置为2017年11月27日也就是今天不执行,并打印出了程序最近的一次的执行时间,是明天。因而可知,排除时间成功。
SimpleTrigger和CronTrigger以前已经介绍过了,接下来介绍一下CalendarIntervalTrigger 和 DailyTimeIntervalTrigger
CalendarIntervalTrigger:是一个具体的Trigger,用来触发基于定时重复的JobDetail。
Trigger将会每隔N个calendar在trigger中定义的时间单元触发一次。这个trigger不适合使用SimpleTrigger完成(例如因为每个月的时间不是固定的描述),也不适用于CronTrigger(例如每5个月)。
相较于SimpleTrigger有两个优点:一、更方便,好比每隔1小时执行,你不用本身去计算1小时等于多少毫秒。 二、支持不是固定长度的间隔,好比间隔为月和年。但劣势是精度只能到秒。
它适合的任务相似于:9:00 开始执行,而且之后每周 9:00 执行一次
它的属性有:
interval 执行间隔
intervalUnit 执行间隔的单位(秒,分钟,小时,天,月,年,星期)
例子:
CalendarIntervalScheduleBuilder .calendarIntervalSchedule() .withIntervalInDays(1) //天天执行一次 //.withIntervalInHours(1) //.withIntervalInMinutes(1) //.withIntervalInMonths(1) //.withIntervalInSeconds(1) //.withIntervalInWeeks(1) //.withIntervalInHours(1) .build()
指定天天的某个时间段内,以必定的时间间隔执行任务。而且它能够支持指定星期。
它适合的任务相似于:指定天天9:00 至 18:00 ,每隔70秒执行一次,而且只要周一至周五执行。
它的属性有:
2.1编写Scheduler类
public static void main(String[] args) throws SchedulerException { SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); //1.建立一个jobDetail的实例,将该实例与HelloJob Class绑定 JobDetail jobDetail = JobBuilder .newJob(HelloJob.class) .withIdentity("myJob", "group1") //定义name 和 group .build(); //2.建立一个Trigger触发器的实例 Trigger simpleTrigger = TriggerBuilder.newTrigger() .withIdentity("zhlTrigger") .withSchedule( DailyTimeIntervalScheduleBuilder.dailyTimeIntervalSchedule() .startingDailyAt(TimeOfDay.hourAndMinuteOfDay(8, 0)) //天天8:00开始 .endingDailyAt(TimeOfDay.hourAndMinuteOfDay(17, 0)) //17:00 结束 .onDaysOfTheWeek(MONDAY,TUESDAY,WEDNESDAY,THURSDAY,FRIDAY) //周一至周五执行 .withIntervalInHours(1) //每间隔1小时执行一次 .withRepeatCount(100) //最多重复100次(实际执行100+1次) ) .modifiedByCalendar("holidays") //将咱们设置好的Calander与trigger绑定 .build(); //3.建立schedule实例 StdSchedulerFactory factory = new StdSchedulerFactory(); Scheduler scheduler = factory.getScheduler(); System.out.println("如今的时间 :"+sf.format(new Date())); System.out.println(); System.out.println("最近的一次执行时间 :"+sf.format(scheduler.scheduleJob(jobDetail,simpleTrigger))); //scheduler与jobDetail、trigger绑定,并打印出最近一次执行的事件 scheduler.start(); }
2.2打印的效果
虽然介绍了Quartz一些基本的用法,可是Quartz的强大不止这些,包括集成Spring,与Spring Boot的集成,quartz的listener,quartz的持久化,集群,插件等等,以后会陆续的介绍。最后,quartz是一个基于java的很是成熟的任务调度框架,适合于任何常规的使用,以及个性化的开发使用, 其次经过数据库的持久化,能够选择实现集群,大大增长了任务调度的可靠性,值得每一个程序人借鉴使用。