spring整合Quartz

本文详细介绍了如何在Spring框架下配置Quartz定时任务,包括pom文件依赖配置、版本兼容注意事项、任务类实现方式及配置文件示例。特别强调了Spring与Quartz版本的匹配,以及使用MethodInvokingJobDetailFactoryBean实现任务类的灵活性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、pom文件配置

<!-- quartz libs for job schedule -->
<dependency>
   <groupId>org.quartz-scheduler</groupId>
   <artifactId>quartz</artifactId>
   <version>2.2.1</version>
</dependency>

二、版本兼容注意事项

spring3.1以下的版本必须使用quartz1.x系列,3.1以上的版本才支持quartz 2.x,不然会出错。

至于原因,则是spring对于quartz的支持实现,org.springframework.scheduling.quartz.CronTriggerBean继承了org.quartz.CronTrigger,在quartz1.x系列中org.quartz.CronTrigger是个类,而在quartz2.x系列中org.quartz.CronTrigger变成了接口,从而造成无法用spring的方式配置quartz的触发器(trigger)。

在Spring中使用Quartz有两种方式实现:第一种是任务类继承QuartzJobBean,第二种则是在配置文件里定义任务类和要执行的方法,类和方法可以是普通类。很显然,第二种方式远比第一种方式来的灵活。

三、实例代码

1、代码结构

2、配置文件

<!-- 使用MethodInvokingJobDetailFactoryBean,任务类可以不实现Job接口,通过targetMethod指定调用方法-->
<bean id="taskJob" class="com.tyyd.dw.task.DataConversionTask"/>
<bean id="jobDetail" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
  <property name="group" value="job_work"/>
  <property name="name" value="job_work_name"/>
  <!--false表示等上一个任务执行完后再开启新的任务-->
  <property name="concurrent" value="false"/>
  <property name="targetObject">
    <ref bean="taskJob"/>
  </property>
  <property name="targetMethod">
    <value>task</value>
  </property>
</bean>
 
<!-- 调度触发器 -->
<bean id="myTrigger"
   class="org.springframework.scheduling.quartz.CronTriggerFactoryBean">
  <property name="name" value="work_default_name"/>
  <property name="group" value="work_default"/>
  <property name="jobDetail">
    <ref bean="jobDetail" />
  </property>
  <property name="cronExpression">
    <value>0/5 * * * * ?</value>
  </property>
</bean>
 
<!-- 调度工厂 -->
<bean id="scheduler" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
  <property name="triggers">
    <list>
      <ref bean="myTrigger"/>
    </list>
  </property>
</bean>

3、任务类

public class DataConversionTask{

  /** 日志*/

  private static final Logger logger = LoggerFactory.getLogger(DataConversionTask.class);

  public void task() {

    if (logger.isInfoEnabled()) {

      logger.info("定时任务开始执行!");

    }

  }

}

4、说明

task方法将每隔5秒执行一次,因为配置了concurrent等于false,所以假如task方法的执行时间超过5秒,在执行完之前即使时间已经超过了5秒下一个定时计划执行任务仍不会被开启,如果是true,则不管是否执行完,时间到了都将开启。

参考文章:https://www.jb51.net/article/107339.htm

作者:       --糖先生

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值