Quartz在Spring中如何动态配置时间.doc
文本预览下载声明
Quartz在Spring中如何动态配置时间
在项目中有一个需求,需要灵活配置调度任务时间,并能自由启动或停止调度。有关调度的实现我就第一就想到了Quartz这个开源调度组件,因为很多项目使用过,Spring结合Quartz静态配置调度任务时间,非常easy。比如:每天凌晨几点定时运行一个程序,这只要在工程中的spring配置文件中配置好spring整合quartz的几个属性就好。Spring配置文件
引用
bean id=jobDetail class=org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBeanproperty name=targetObject ref=simpleService /property name=targetMethod value=test //beanbean id=cronTrigger class=org.springframework.scheduling.quartz.CronTriggerBeanproperty name=jobDetail ref=jobDetail /property name=cronExpression value=0 0/50 * ? * * * //beanbean? id=schedulerTrigger class=org.springframework.scheduling.quartz.SchedulerFactoryBeanproperty name=triggerslistref bean=cronTrigger/ ?? ?/list/property/bean
这种配置就是对quartz的一种简单的使用了,调度任务会在spring启动的时候加载到内存中,按照cronTrigger中定义的 cronExpression定义的时间按时触发调度任务。但是这是quartz使用“内存”方式的一种配置,也比较常见,当然对于不使用spring的项目,也可以单独整合quartz。方法也比较简单,可以从quartz的doc中找到配置方式,或者看一下《Quartz Job Scheduling Framework 》。但是对于想持久化调度任务的状态,并且灵活调整调度时间的方式来说,上面的内存方式就不能满足要求了,正如本文开始我遇到的情况,需要采用数据库方式集成 Quartz,这部分集成其实在《Quartz Job Scheduling Framework 》中也有较为详细的介绍,当然doc文档中也有,但是缺乏和spring集成的实例。一、需要构建Quartz数据库表,建表脚本在Quartz发行包的docs\dbTables目录,里面有各种数据库建表脚本,我采用的Quartz 1.6.5版本,总共12张表,不同版本,表个数可能不同。我用mysql数据库,执行了Quartz发行包的docs\dbTables\tables_mysql_innodb.sql建表。二、建立java project,完成后目录如下?project,完成后目录如下??三、配置数据库连接池配置perties文件
引用
jdbc.driverClassName=com.mysql.jdbc.Driverjdbc.url=jdbc:mysql://localhost:3306/quartz?useUnicode=truecharacterEncoding=UTF-8autoReconnect=truejdbc.username=rootjdbc.password=kfscpool.checkoutTimeout=5000cpool.minPoolSize=10cpool.maxPoolSize=25cpool.maxIdleTime=7200cpool.acquireIncrement=5cpool.autoCommitOnClose=true
配置applicationContext.xml文件
引用
?xml version=1.0 encoding=UTF-8?beans xmlns=/schema/beans??? xmlns:xsi=/2001/XMLSchema-instance??? xmlns:aop=/schema/aop??? xmlns:tx=/schema/tx??? xmlns:context=/schema/context???? xmlns:jee=/schema/jee??? xsi:schemaLocation=??? /schema/context /schema
显示全部