`

Spring对Quartz提供的任务调度支持

阅读更多

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">5</prop>
      </props>
</property>
</bean>
有关Quartz更深入的内容,请参考其官方网站。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics