Spring框架提供了丰富的Quartz任务调度支持,比如,在何时执行何种任务,它是一个开源的由OpenSymphony维护的项目,开发者能够在 Java EE,或单独的Java SE应用中使用它。无论是简单的任务调度,还是复杂的企业级应用,Quartz都能够很好地胜任。其中,这些任务可以是普通POJO,甚至还可以是EJB 3.0组件。
如果开发者需要开发如下方面的应用,则Quartz是理想的选择。
◆驱动工作流:比如,如果新创建的流程任务需要在2小时内处理完,则在2小时后Quartz会检查订单是否成功处理。如果没有处理,则Quartz会依据工作流定义的规则来对订单进行处理,销毁它,或者进行其他处理。
◆系统维护工作:比如,在每个工作日的固定时间将RDBMS中的内容导出为XML文件。
Spring 2.0提供了org.springframework.scheduling.quartz包,以支持Quartz任务调度集成。为提供用户的任务,开发者实现的类必须继承于quartz.QuartzJobBean抽象类。QuartzJobBean是Quartz中org.quartz.Job接口的简单实现(子类),Spring为简化Job接口的实现而提供了QuartzJobBean类。QuartzJobBean同Java 2 SDK中的TimerTask类似,用于定义任务本身。其中,executeInternal()方法定义待执行的任务,这同TimerTask中的 run()类似。下面给出了imagedb中ListImagesQuartzJob的定义,它同ListImagesTimerTask几乎没有区别。
- public class ListImagesQuartzJob extends QuartzJobBean {
- private ImageDatabase imageDatabase;
- private MailSender mailSender;
- private String mailFrom;
- private String mailTo;
- public void setImageDatabase(ImageDatabase imageDatabase) {
- this.imageDatabase = imageDatabase;
- }
- public void setMailSender(MailSender mailSender) {
- this.mailSender = mailSender;
- }
- public void setMailFrom(String mailFrom) {
- this.mailFrom = mailFrom;
- }
- public void setMailTo(String mailTo) {
- this.mailTo = mailTo;
- }
- protected void executeInternal(JobExecutionContext context) {
- ......
- logger.info("Next job execution at: " + context.getNextFireTime());
- }
- }
开发者可以通过executeInternal()方法指定待完成的用户任务,而通过传入它的context能够获得任务执行的上下文信息,比如,下次执行用户任务的时间。随后,我们要指定相应的调度规则,下面给出了context/WEB-INF/schedulingContext- quartz.xml中的相关配置信息。JobDetailBean是Quartz中org.quartz.JobDetail的子类,Spring为简化JobDetail子类的开发而提供了JobDetailBean。借助于JobDetailBean中的jobClass属性能够设置Job对象类型,而借助于jobDataAsMap属性能够为ListImagesQuartzJob的各个属性提供目标取值。
- <bean id="listImagesJobDetail" class="org.springframework.scheduling.quartz.
- JobDetailBean">
- <property name="jobClass" value="org.springframework.samples.imagedb.
- scheduling.ListImagesQuartzJob"/>
- <property name="jobDataAsMap">
- <map>
- <entry key="imageDatabase" value-ref="imageDatabase"/>
- <entry key="mailSender" value-ref="mailSender"/>
- <entry key="mailFrom" value="${mail.from}"/>
- <entry key="mailTo" value="${mail.to}"/>
- map>
- property>
- bean>
- <bean id="listImagesTrigger" class="org.springframework.scheduling.quartz.
- SimpleTriggerBean">
- <property name="jobDetail" ref="listImagesJobDetail"/>
- <property name="startDelay" value="10000"/>
- <property name="repeatInterval" value="10000"/>
- bean>
SimpleTriggerBean是Quartz中org.quartz.SimpleTrigger的子类,为简化SimpleTrigger 子类的开发,Spring提供了它。为指定调度规则,开发者需要使用它设定运行任务的频率和时机。SimpleTriggerBean同Timer任务调度中的ScheduledTimerTask类似,但功能上比它更强大。此时,SimpleTriggerBean暴露的startDelay属性的含义同ScheduledTimerTask中的delay属性,而repeatInterval属性同period属性。
为了指定更复杂的任务调度规则,开发者要使用Spring提供的CronTriggerBean,它是Quartz中 org.quartz.CronTrigger的子类,Spring 2.0为简化CronTrigger子类的开发而提供了CronTriggerBean。CronTriggerBean比 SimpleTriggerBean功能更强大,它能够控制任务执行的精确时间,比如,早上九点半需要执行某QuartzJobBean中给定的任务。借助于CronTriggerBean中的cronExpression属性能够设定任务的执行时机。下面展示了相应的配置示例。
- <bean id="checkImagesJobDetail"
- class="org.springframework.scheduling.quartz.
- MethodInvokingJobDetailFactoryBean">
- <property name="targetObject" ref="imageDatabase"/>
- <property name="targetMethod" value="checkImages"/>
- <property name="concurrent" value="true"/>
- bean>
- <bean id="checkImagesTrigger"
- class="org.springframework.scheduling.quartz.CronTriggerBean">
- <property name="jobDetail" ref="checkImagesJobDetail"/>
- <property name="cronExpression" value="0/5 * * * * ?"/>
- bean>
上述配置片断还使用到MethodInvokingJobDetailFactoryBean,它能够将普通的POJO指定为用户任务。这也是Spring Quartz任务调度集成支持的另一种指定用户任务的策略。
在制订上述2条调度规则后,开发者要实施它们,而SchedulerFactoryBean能够担当此任,示例配置如下。借助于triggers属性,开发者能够指定由若干SimpleTriggerBean和CronTriggerBean构成的集合;借助于quartzProperties属性,开发者能够控制Quartz的具体细节,比如,线程池中线程的数量。
- <bean id="scheduler" class="org.springframework.scheduling.quartz.
- SchedulerFactoryBean">
- <property name="triggers">
- <list>
- <ref local="listImagesTrigger"/>
- <ref local="checkImagesTrigger"/>
- list>
- property>
- <property name="quartzProperties">
- <props>
- <prop key="org.quartz.threadPool.threadCount">5prop>
- props>
- property>
- bean>
【编辑推荐】