文档详情

Quartz学习资料.doc

发布:2018-04-09约4.17万字共44页下载文档
文本预览下载声明
Quartz学习 介绍Quartz Quartz是一个开源的任务调度系统,它能用来调度很多任务的执行。 运行环境 Quartz 能嵌入在其他应用程序里运行。 Quartz 能在一个应用服务器里被实例化(或servlet容器), 并且参与XA事务 Quartz能独立运行(通过JVM),或者通过RMI Quartz能被集群实例化 任务调度 当一个指定给任务的触发器发生时,任务就被调度执行. 触发器能被创建为: 一天的某个时间(精确到毫秒级) 一周的某些天 一个月的某些天 一年的某些天 不在一个Calendar列出的某些天 (例如工作节假日) 在一个指定的次数重复 重复到一个指定的时间/日期 无限重复 在一个间隔内重复 能够给任务指定名称和组名.触发器也能够指定名称和组名,这样可以很好的在调度器里组织起来.一个加入到调度器里的任务可以被多个触发器注册。在J2EE环境里,任务能作为一个分布式(XA)事务的一部分来执行。 任务执行 任务能够是任何实现Job接口的Java类。 任务类能够被Quartz实例化,或者被你的应用框架。 当一个触发器触发时,调度器会通知实例化了JobListener 和TriggerListener 接口的0个或者多个Java对象(监听器可以是简单的Java对象, EJBs, 或JMS发布者等). 在任务执行后,这些监听器也会被通知。 当任务完成时,他们会返回一个JobCompletionCode ,这个代码告诉调度器任务执行成功或者失败.这个代码 也会指示调度器做一些动作-例如立即再次执行任务。 任务持久化 Quartz的设计包含JobStore接口,这个接口能被实现来为任务的存储提供不同的机制。 应用JDBCJobStore, 所有被配置成“稳定”的任务和触发器能通过JDBC存储在关系数据库里。 应用RAMJobStore, 所有任务和触发器能被存储在RAM里因此不必在程序重起之间保存-一个好处就是不必使用数据库。 事务 使用JobStoreCMT(JDBCJobStore的子类),Quartz 能参与JTA事务。 Quartz 能管理JTA事务(开始和提交)在执行任务之间,这样,任务做的事就可以发生在JTA事务里。 集群 Fail-over. Load balancing. 监听器和插件 通过实现一个或多个监听接口,应用程序能捕捉调度事件来监控或控制任务/触发器的行为。 插件机制可以给Quartz增加功能,例如保持任务执行的历史记录,或从一个定义好的文件里加载任务和触发器。 Quartz 装配了很多插件和监听器。 1.使用Quartz 在我们用调度器之前,调度器需要实例化。我们用SchedulerFactory 来实例它。一旦调度器被实例,我们就可以启动它,置它为stand-by模式,最后关闭它。注意:一旦一个调度器被关闭了,如果我们不重新实例化它,它就不可能被再次启动。直到调度器启动了或者当调度器处于暂停状态,触发器才能够触发。下面有个简单的例子: SchedulerFactory schedFact = new org.quartz.impl.StdSchedulerFactory(); Scheduler sched = schedFact.getScheduler(); sched.start(); JobDetail jobDetail = new JobDetail(myJob, null, DumbJob.class); Trigger trigger = TriggerUtils.makeHourlyTrigger(); // 每个小时触发 trigger.setStartTime(TriggerUtils.getEvenHourDate(new Date())); // 在下个小时开始 trigger.setName(myTrigger); sched.scheduleJob(jobDetail, trigger); 就象你看到的,使用Quartz是很简单的。在下一节我们介绍Jobs和Triggers。 2.Jobs 和 Triggers 就象以前提到的,一个实现了Job接口的Java类就能够被调度器执行。接口如下: package org.quartz; public interface Job { public void execute(JobExecutionContext context) throws JobExecutionException; } 很简的,当Job的trigger触发时,Job的execute(..)方法就会被调度器调用。被传递到这个方法里来的JobExecutionContext对象提供了带有job运行
显示全部
相似文档