quartz在spring中的应用

1. Overview 
  为了降低使用Quartz的难度,并能以Spring风格的方式使用Quartz,Spring为Quartz提供了Scheduler, Trigger, JobDetail的FactoryBean类,以及一些工具类,使Quartz能很好的注入容器,并可以结合Spring容器的生命周期,启动和关闭job。 

2. JobDetailBean 
  使用JobDetailBean,需要设置其JobClass属性,指定实现了Job接口的实现类。JobDetailBean默认使用bean名作为job名,DEFAULT作为组名,并可以通过applicationContextJobDataKey键,将ApplicationContext设置到JobDataMap中。JobDetailBean支持以Map方式设置JobDataMap。jobListenerNames属性用于指定job的监听器,类型为String[]。以下是一个例子: 
Java代码   收藏代码
  1. <bean name="jobDetail" class="org.springframework.scheduling.quartz.JobDetailBean">  
  2.         <property name="jobClass" value="com.tboy.example.quartz.MyJobClass" />  
  3.         <property name="applicationContextJobDataKey" value="applicationContext"/>  
  4.         <property name="jobDataAsMap">  
  5.             <map>  
  6.                 <entry key="container" value="Tomcat"/>  
  7.             </map>  
  8.         </property>  
  9.     </bean>  

通过jobClass设置了Job实现类,并设置了Job的JobDataMap,指定了applicationContextJobDataKey键,让Job的JobDataMap持有Spring ApplicationContext的引用。以下是MyJobClass的伪实现: 
Java代码   收藏代码
  1. public class MyJobClass implements Job{  
  2.   
  3.     @Override  
  4.     public void execute(JobExecutionContext context)  
  5.             throws JobExecutionException {  
  6.         Map dataMap = context.getJobDetail().getJobDataMap();  
  7.         String container = (String)dataMap.get("container");  
  8.         ApplicationContext applicationContext = (ApplicationContext)dataMap.get("applicationContext");  
  9.         //applicationContext.getBean("");  
  10.         if(container.equals("Tomcat")){  
  11.             //  
  12.         }  
  13.         //  
  14.     }  
  15. }  


3. JobDetailFactoryBean 
  由于JobDetailBean继承org.quartz.JobDetail,在Quartz 2.0以后,JobDetail改为接口,所以JobDetailBean不支持Quartz 2.0以上版本。如果使用Quartz2.0以上版本,可以使用JobDetailFactoryBean。支持的属性设置,与JobDetailBean相同。 

4. MethodInvokingJobDetailFactoryBean 
  通常情况下,我们都是实现Job接口定义任务,为了避免这种只包含一行调用代码的Job实现类,Spring提供了MethodInvokingJobDetailFactoryBean,可以将一个Bean的某个方法封装成满足Quartz要求的Job。以下是一个例子: 
Java代码   收藏代码
  1. <bean id="myJob" class="com.tboy.example.quartz.MyJob" />  
  2.       
  3.     <bean id="jobDetail" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">  
  4.         <property name="targetObject" ref="myJob" />  
  5.         <property name="targetMethod" value="work" />  
  6.         <property name="concurrent" value="true"/>  
  7.     </bean>  

jobDetail将myJob的work方法封装成一个Job。concurrent属性指定任务的类型,如果为有状态的任务,设置为false即可,默认为true。以下是myJob的伪实现: 
Java代码   收藏代码
  1. public class MyJob {  
  2.       
  3.     public void work(){  
  4.         //  
  5.     }  
  6. }  

  work方法可以是static,也可以是非static的。但不能有方法入参。由于MethodInvokingJobDetailFactoryBean实现中通过JobExecutionContext取得Scheduler, 而Scheduler不能被序列化,那么创建的JobDetail也不能被序列化,也就不能持久化到数据库,如果想持久化到数据库,只能通过创建Job实现类的方式。MethodInvokingJobDetailFactoryBean支持quartz1.5以2.0以上版本。 

5. SimpleTriggerBean 
  使用SimpleTriggerBean需要设置jobDetail。SimpleTriggerBean默认使用bean名作为trigger的名称,DEFAULT作为默认组。startDelay属性可以设置延迟触发trigger的时间,单位为毫秒,默认为0。支持以Map方式设置trigger的JobDataMap。以下是一个例子: 
Java代码   收藏代码
  1. <bean id="simpleTrigger" class="org.springframework.scheduling.quartz.SimpleTriggerBean">  
  2.         <property name="jobDetail" ref="jobDetail"/>  
  3.         <property name="startDelay" value="1000" />  
  4.         <property name="repeatCount" value="5"/>  
  5.         <property name="repeatInterval" value="2000"/>  
  6.         <property name="jobDataAsMap">  
  7.             <map>  
  8.                 <entry key="count" value="10"/>  
  9.             </map>  
  10.         </property>  
  11.     </bean>  

在job实现类中,通过以下方式取得jobDataMap: 
Java代码   收藏代码
  1. public class MyJob implements Job{  
  2.   
  3.     @Override  
  4.     public void execute(JobExecutionContext context)  
  5.             throws JobExecutionException {  
  6.         Map dataMap = context.getTrigger().getJobDataMap();  
  7.         Object count = dataMap.get("count");  
  8.         System.out.println(count);  
  9.     }  
  10. }  


6. SimpleTriggerFactoryBean 
  由于SimpleTriggerBean继承了org.quartz.SimpleTrigger,因此不支持Quartz2.0以上版本。如果使用Quartz2.0以上版本,可以使用SimpleTriggerFactoryBean。支持的属性设置,与SimpleTriggerBean相同。 

7. CronTriggerBean 
  CronTriggerBean支持的属性,与SimpleTriggerBean相同。以下是一个例子: 
Java代码   收藏代码
  1. <bean id="cronTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">  
  2.         <property name="jobDetail" ref="jobDetail"/>  
  3.         <property name="startDelay" value="1000" />  
  4.         <property name="cronExpression">  
  5.             <value>0/30 * * * * ?</value>  
  6.         </property>  
  7.     </bean>  


8. CronTriggerFactoryBean 
  如果使用Quartz2.0以上版本,可以使用CronTriggerFactoryBean。支持的属性设置,与CronTriggerBean相同。 

9. SchedulerFactoryBean 
  Spring提供了SchedulerFactoryBean,可以让Scheduler感知Spring容器的生命周期,在容器启动时,Scheduler自动开始工作,容器关闭前,自动关闭Scheduler。以下是一个例子: 
Java代码   收藏代码
  1. <bean id="executor" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">  
  2.         <property name="corePoolSize" value="3" />  
  3.         <property name="maxPoolSize" value="5" />  
  4.         <property name="queueCapacity" value="10" />  
  5.     </bean>  
  6.   
  7. <bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean">  
  8.         <property name="triggers">  
  9.             <list>  
  10.                 <ref bean="transferJobCronTrigger" />  
  11.                 <ref bean="deleteJobCronTrigger" />  
  12.                 <ref bean="softDeleteJobCronTrigger" />  
  13.             </list>  
  14.         </property>  
  15.         <property name="autoStartup" value="true"/>  
  16.         <property name="startupDelay" value="5"/>  
  17.         <property name="schedulerContextAsMap">  
  18.             <map>  
  19.                 <entry key="timeout" value="30"/>  
  20.             </map>  
  21.         </property>  
  22.         <property name="taskExecutor" ref="executor" />  
  23.         <property name="configLocation" value="classpath:com/tboy.example/quartz/quartz.properties"/>  
  24.     </bean>  

默认情况下,Quartz在类路径下寻找quartz.properties配置文件,可以通过configLocation属性显示指定配置文件的位置。startupDelay属性指定延迟多少时间让容器启动Scheduler,单位为秒。schedulerContextAsMap属性设置了SchedulerContext数据,可以在job中通过JobExecutionContext.getScheduler().getContext().getXxx()方法获取。通过taskExecutor属性设置线程池。支持以Properties方式设置Quartz属性,将覆盖配置文件的值: 
Java代码   收藏代码
  1. <property name="quartzProperties">  
  2.    <props>  
  3.     <prop key="org.quartz.threadPool.class">  
  4.            org.quartz.simpl.SimpleThreadPool  
  5.     </prop>  
  6.     <prop key="org.quartz.threadPool.threadCount">10</prop>  
  7.     <prop key="org.quartz.threadPool.threadPriority">5</prop>  
  8.  <prop key="org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread">  
  9. true</prop>  
  10.     </props>  
  11. </property>  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值