Quartz学习资料

Quartz学习资料

ID:40565371

大小:157.50 KB

页数:44页

时间:2019-08-04

Quartz学习资料_第1页
Quartz学习资料_第2页
Quartz学习资料_第3页
Quartz学习资料_第4页
Quartz学习资料_第5页
资源描述:

《Quartz学习资料》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、Quartz学习介绍QuartzQuartz是一个开源的任务调度系统,它能用来调度很多任务的执行。运行环境Quartz能嵌入在其他应用程序里运行。Quartz能在一个应用服务器里被实例化(或servlet容器),并且参与XA事务Quartz能独立运行(通过JVM),或者通过RMIQuartz能被集群实例化任务调度当一个指定给任务的触发器发生时,任务就被调度执行.触发器能被创建为:一天的某个时间(精确到毫秒级)一周的某些天一个月的某些天一年的某些天不在一个Calendar列出的某些天(例如工作节假日)在一个指定的次数重复重复到一个指定的时间/日期无限重复在一个间隔内重复能够给

2、任务指定名称和组名.触发器也能够指定名称和组名,这样可以很好的在调度器里组织起来.一个加入到调度器里的任务可以被多个触发器注册。在J2EE环境里,任务能作为一个分布式(XA)事务的一部分来执行。任务执行任务能够是任何实现Job接口的Java类。任务类能够被Quartz实例化,或者被你的应用框架。当一个触发器触发时,调度器会通知实例化了JobListener和TriggerListener接口的0个或者多个Java对象(监听器可以是简单的Java对象,EJBs,或JMS发布者等).在任务执行后,这些监听器也会被通知。当任务完成时,他们会返回一个JobCompletionCod

3、e,这个代码告诉调度器任务执行成功或者失败.这个代码也会指示调度器做一些动作-例如立即再次执行任务。任务持久化Quartz的设计包含JobStore接口,这个接口能被实现来为任务的存储提供不同的机制。应用JDBCJobStore,所有被配置成“稳定”的任务和触发器能通过JDBC存储在关系数据库里。应用RAMJobStore,所有任务和触发器能被存储在RAM里因此不必在程序重起之间保存-一个好处就是不必使用数据库。事务使用JobStoreCMT(JDBCJobStore的子类),Quartz能参与JTA事务。Quartz能管理JTA事务(开始和提交)在执行任务之间,这样,任务

4、做的事就可以发生在JTA事务里。集群Fail-over.Loadbalancing.监听器和插件通过实现一个或多个监听接口,应用程序能捕捉调度事件来监控或控制任务/触发器的行为。插件机制可以给Quartz增加功能,例如保持任务执行的历史记录,或从一个定义好的文件里加载任务和触发器。Quartz装配了很多插件和监听器。1.使用Quartz在我们用调度器之前,调度器需要实例化。我们用SchedulerFactory来实例它。一旦调度器被实例,我们就可以启动它,置它为stand-by模式,最后关闭它。注意:一旦一个调度器被关闭了,如果我们不重新实例化它,它就不可能被再次启动。直到

5、调度器启动了或者当调度器处于暂停状态,触发器才能够触发。下面有个简单的例子:SchedulerFactoryschedFact=neworg.quartz.impl.StdSchedulerFactory();Schedulersched=schedFact.getScheduler();sched.start();JobDetailjobDetail=newJobDetail("myJob",null,DumbJob.class);Triggertrigger=TriggerUtils.makeHourlyTrigger();//每个小时触发trigger.setStar

6、tTime(TriggerUtils.getEvenHourDate(newDate()));//在下个小时开始trigger.setName("myTrigger");sched.scheduleJob(jobDetail,trigger);就象你看到的,使用Quartz是很简单的。在下一节我们介绍Jobs和Triggers。2.Jobs和Triggers就象以前提到的,一个实现了Job接口的Java类就能够被调度器执行。接口如下:packageorg.quartz;publicinterfaceJob{publicvoidexecute(JobExecutionCont

7、extcontext)throwsJobExecutionException;}很简的,当Job的trigger触发时,Job的execute(..)方法就会被调度器调用。被传递到这个方法里来的JobExecutionContext对象提供了带有job运行时的信息:执行它的调度器句柄、触发它的触发器句柄、job的JobDetail对象和一些其他的项。JobDetail对象是Job在被加到调度器里时所创建的,它包含有很多的Job属性设置,和JobDataMap一样,可以用来存储job实例时的一些状态信息。Trigge

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。