该文章来源于网页整理.
1.quartz.properties配置文件说明
在集群中每个实例都必须有一个唯一的instanceId,但是应该有一个相同的instanceName
org.quartz.scheduler.instanceName = TestSchedulerorg.quartz.scheduler.instanceId = AUTO 定义线程池,SimpleThreadPool这个线程池只是简单地在它的池中保持固定数量的线程,不增长也不缩小。但是它非常健壮且经过良好的测试,差不多每个Quartz用户都使用这个池。org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPoolorg.quartz.threadPool.threadCount = 3 最多只能有3个线程并发一个触发器被认定为“misfired”之前,调度器所能容忍的毫秒数
org.quartz.jobStore.misfireThreshold = 60000所有的Quartz数据,例如Job和Trigger的细节信息被存储在内存(数据库)中。
org.quartz.jobStore.class = org.quartz.simpl.RAMJobStore#org.quartz.jobStore.class = org.quartz.simpl.JDBCJobStoreJobStoreTX来让Quartz帮你管理事务(这是最普遍的选择)。
如果想让Quartz同其他的事务协同工作(例如:J2EE应用服务器中的事务),那么你需要使用JobStoreCMT,这样,Quartz就会让应用服务器容器来管理事务org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTXorg.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreCMTDriverDelegate负责做指定数据库的所有JDBC工作.
如果数据库没有其他指定的代理,那么就试用代理StdJDBCDelegate。org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.StdJDBCDelegate为了指示JDBCJobStore所有的JobDataMaps中的值都是字符串,并且能以“名字-值”对的方式存储而不是以复杂对象的序列化形式存储在BLOB字段中,应设置值为”true”(这是缺省的方式)。
org.quartz.jobStore.useProperties = true配置数据源源的名数、据库表前前缀
#org.quartz.jobStore.dataSource = myDS#org.quartz.jobStore.tablePrefix = QRTZ_是否集群 负载均衡和容错
#org.quartz.jobStore.isClustered = false配置数据源
#org.quartz.dataSource.myDS.driver = org.postgresql.Driver#org.quartz.dataSource.myDS.URL = jdbc:postgresql://localhost/dev#org.quartz.dataSource.myDS.user = jhouse#org.quartz.dataSource.myDS.password =如果Scheduler非常忙(比如,执行的任务数量差不多和线程池的数量相同,那么你需要正确地配置DataSource的连接数量为线程池数量+1)
#org.quartz.dataSource.myDS.maxConnections = 5 2.spring定时任务之quartz
1) 编写业务类,该类继承了org.quartz.Job,主要的逻辑在execute方法中编写
2) 配置spring的applicationContext.xml文件
2.1 配置任务JobDetailBean 2.2配置触发器 CronTriggerBean2.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:package task;
import java.util.Date;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;public class Busine***eport 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" ""><!-- <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" ":/spring-beans.dtd">--><beans> <bean id="busine***eport" class="task.Busine***eport" /><bean name="reportTask" class="org.springframework.scheduling.quartz.JobDetailBean"> <property name="jobClass" value="task.Busine***eport" /> </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>3.
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时触发.