spring定时任务之quartz
quartzSpringBeanMySQLOracle
在Spring中,使用JDK的Timer类库来做任务调度功能不是很方便,关键它不可以象cron服务那样可以指定具体年、月、日、时和分的时间。你只能将时间通过换算成微秒后传给它。如任务是每天执行一次,则需要在spring中如下配置:
<bean id="scheduledTask" class= "org.springframework.scheduling.timer.ScheduledTimerTask">
<!--程序启动后开始执行任务的延迟时间 -->
<property name="delay" value="0" />
<!--每隔一天【一天=24×60×60×1000微秒】执行一次-->
<property name="period" value="86400000" />
<!--业务统计报表bean -->
<property name="timerTask" ref="businessReport" />
</bean>
其中period就是一天的微秒数。如果每月1日运行一次,那就复杂了,不知如何配置。因为月份有大、小月之分,每月的微秒数都不一样。
而Quartz类库不但有着上述JDK的Timer类库类似的配置,更重要的,它还有着类似于unix的cron服务的配置。因此,在迁移中我们采用了Quartz类库的接口。
具体的步骤如下:
1 编写业务类,该类继承了org.quartz.Job,主要的逻辑在execute方法中编写
2 配置spring的applicationContext.xml文件
2.1 配置任务JobDetailBean
2.2配置触发器 CronTriggerBean
2.3配置调度器 SchedulerFactoryBean
3 所需要的jar包:
spring.jar,quartz.jar,commons-logging-1.0.4.jar,commons-dbcp-1.2.2.jar,commons-pool-1.3.jar
4 把quartz.properties放到类路径下
以下为一个demo
业务类:
Java代码
package task;
import java.util.Date;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
public class BusinessReport implements org.quartz.Job{
public void perform(){ //执行报表统计入口函数
//业务逻辑
System.out.println("开始执行报表的业务逻辑了----现在的时间是--"+new Date());
}
public void execute(JobExecutionContext arg0) throws JobExecutionException {
perform();
}
}
applicationContext.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">
<!--
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" ":/spring-beans.dtd">
-->
<beans>
<bean id="businessReport" class="task.BusinessReport" />
<bean name="reportTask"
class="org.springframework.scheduling.quartz.JobDetailBean">
<property name="jobClass" value="task.BusinessReport" />
</bean>
<!-- 触发器 -->
<bean id="cronTrigger"
class="org.springframework.scheduling.quartz.CronTriggerBean">
<!-- 指向我们的任务 -->
<property name="jobDetail" ref="reportTask" />
<!-- 每天下午16点50分到55分,每分钟运行一次 -->
<property name="cronExpression" value="0 50-55 16 * * ?" />
</bean>
<!-- 调度器 -->
<bean
class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<property name="triggers">
<list>
<!-- 触发器列表 -->
<ref bean="cronTrigger" />
</list>
</property>
<property name="configLocation" value="classpath:quartz.properties" />
</bean>
</beans>
三 quartz.properties文件的内容(默认放在类路径下)
#============================================================================# Configure Main Scheduler Properties #============================================================================org.quartz.scheduler.instanceName = DefaultQuartzSchedulerorg.quartz.scheduler.instanceId = AUTOorg.quartz.scheduler.rmi.export = falseorg.quartz.scheduler.rmi.proxy = falseorg.quartz.scheduler.wrapJobExecutionInUserTransaction = false#============================================================================# Configure ThreadPool #============================================================================#org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPoolorg.quartz.threadPool.threadCount = 10org.quartz.threadPool.threadPriority = 5#org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread = true#============================================================================# Configure JobStore #============================================================================#org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX#org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.oracle.OracleDelegateorg.quartz.jobStore.misfireThreshold = 60000#org.quartz.jobStore.useProperties = false#org.quartz.jobStore.tablePrefix = QRTZ_#org.quartz.jobStore.dataSource = myDS#org.quartz.jobStore.isClustered = true#org.quartz.jobStore.clusterCheckinInterval = 15000#============================================================================# Configure DataSource#============================================================================org.quartz.dataSource.myDS.driver = com.mysql.jdbc.Driverorg.quartz.dataSource.myDS.URL = jdbc:mysql://localhost/testorg.quartz.dataSource.myDS.user = rootorg.quartz.dataSource.myDS.password = rootorg.quartz.dataSource.myDS.maxConnections = 10
spring 定时任务中cronExpression表达式含义
一个cron表达式有6个必选的元素和一个可选的元素,各个元素之间是以空格分隔的,从左至右,这些元素的含义如下表所示:
代表含义 是否必须 允许的取值范围 允许的特殊符号秒 是 0-59 , - * /分钟 是 0-59 , - * /小时 是 0-23 , - * /月份中的天数 是 1-31 , - * / ? L W C月份 是 1-12或JAN-DEC , - * /星期中的天数 是 1-7或SUN-SAT , - * / ? L #年 否 empty,1970-2099 , - * /
*:代表所有可取的值,比如说,如果分钟为*,那么就表示每一分钟;
?:只有月份中的天数和星期中的天数可以使用?来表示,因为“月份中的天数”和“星
期中的天数”不能同时设值,所以我们可以通过?来表明不想设置的那个元素;
-:用来指定一个范围类的值,比如说,小时为”10-12”,它就表示10点、11点、12点
,:逗号用来分隔一个元素的多个值,比如说“星期中的天数”为"MON,WED,FRI",
它就表示周一、周三和周五。
/:斜杠用来表示间隔,比如说,秒数为5/10,那么它就表示第5秒、第15秒、第
25秒、第35秒、第45秒和第55秒。斜杠前的数字表示起始位置,后面的数字表
示每次增长的数量。
L:仅用在“月份中的天数”和“星期中的天数”元素中。如果是前者,它代表某月的
最后一天;如果是后者,它就表示是周六。有一点特别的,当表示“星期中的天数”
时,L可以和数字一起用,比如”6L”,它就表示这个月的最后一个星期五。
W:只能用来表示“月份中的天数”,和数字一起使用。比如说15W,它就表示离这
个月15号最近的工作日。使用W时,“月份中的天数”必须为一个指定的日期,
而不能是一个范围的日期。
#:只能用来表示“星期中的天数”。例如5#4,它表示某个月中第四个星期四,2#1
表示某个月中第一个星期一。#前面的数字代表星期,后面的数字表示是第几个。
附:cronExpression表达式解释:0 0 12 * * ?---------------在每天中午12:00触发 0 15 10 ? * *---------------每天上午10:15 触发 0 15 10 * * ?---------------每天上午10:15 触发 0 15 10 * * ? *---------------每天上午10:15 触发 0 15 10 * * ? 2005---------------在2005年中的每天上午10:15 触发 0 * 14 * * ?---------------每天在下午2:00至2:59之间每分钟触发一次 0 0/5 14 * * ?---------------每天在下午2:00至2:59之间每5分钟触发一次 0 0/5 14,18 * * ?---------------每天在下午2:00至2:59和6:00至6:59之间的每5分钟触发一次 0 0-5 14 * * ?---------------每天在下午2:00至2:05之间每分钟触发一次 0 10,44 14 ? 3 WED---------------每三月份的星期三在下午2:00和2:44时触发 0 15 10 ? * MON-FRI---------------从星期一至星期五的每天上午10:15触发 0 15 10 15 * ?---------------在每个月的每15天的上午10:15触发 0 15 10 L * ?---------------在每个月的最后一天的上午10:15触发 0 15 10 ? * 6L---------------在每个月的最后一个星期五的上午10:15触发 0 15 10 ? * 6L 2002-2005---------------在2002, 2003, 2004 and 2005年的每个月的最后一个星期五的上午10:15触发 0 15 10 ? * 6#3---------------在每个月的第三个星期五的上午10:15触发 0 0 12 1/5 * ?---------------从每月的第一天起每过5天的中午12:00时触发 0 11 11 11 11 ?---------------在每个11月11日的上午11:11时触发.
spring定时任务之quartz
最新推荐文章于 2022-11-24 21:50:37 发布