Quartz Spring 例子

由于最近项目需要,由于源数据库的数据量相当的大(数据量少的表有几万条数据,多的表有几百万条数据),所以每次用户要查看汇总数据时,并不可能每次都要从这几百万条数据中执行查询语句,进而作汇总处理。而是要求系统能够定时的执行某些函数,进行数据中间库的生成,而不是由用户去主动触发函数。上网查了一下,开源框架spring + quartz正好能实现这一需求,所以在此把参考网上的结合自己的项目,做了个简单的测试,并记录下来,以备后用。
首先是导入相关的jar包。
其次是JobSchedule.java
package jobSchedule;

import java.text.SimpleDateFormat;
import java.util.Date;

import org.apache.log4j.Logger;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.springframework.scheduling.quartz.QuartzJobBean;

public class JobSchedule extends QuartzJobBean {
static Logger logger = Logger.getLogger(JobSchedule.class);
static long counter = 0; //计数器
public synchronized void doTimerSchedule()
{
counter++;
System.out.println("测试定时器,总计数:"+String.valueOf(counter));
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
System.out.println("当前时间:"+df.format(new Date()));
System.out.println("---------------------------------");
}


protected void executeInternal(JobExecutionContext arg0)
throws JobExecutionException {
// TODO Auto-generated method stub

}

public synchronized void doBuildIndex()
{
System.out.println("开始构造索引库....");
// String indexPath = ServiceLocator.getSysConfigService().getStringValueByParmName("luceneIndexDir");
// String filePath = ServiceLocator.getSysConfigService().getStringValueByParmName("searchRoot");
// IndexHTML.buildIndex(indexPath,filePath);
System.out.println("索引库构造完毕!");
}
}

再是applicationContext.xml的配置文件

<!-- Timer schedule -->
<!--要调度的对象-->
<bean id="defaultTimerBean" class="jobSchedule.JobSchedule"/>
<bean id="defaultTimerMethod" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<property name="targetObject" ref="defaultTimerBean" />
<property name="targetMethod" value="doTimerSchedule" />
<property name="concurrent" value="false" /> <!--将并发设置为false-->
</bean>
<bean id="defaultTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
<property name="jobDetail" ref="defaultTimerMethod" />
<!--每三分钟的第一分钟触发-->
<property name="cronExpression" value="0 1/3 * * * ?" />
</bean>
<!-- 总管理 -->
<bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<property name="triggers">
<list>
<!--作业调度器,list下可加入其他的调度器-->
<ref bean="defaultTrigger"/>
<ref bean="luceneTimerTrigger"/>
</list>
</property>
</bean>

<bean id="luceneTimerMethod" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<property name="targetObject" ref="defaultTimerBean" />
<property name="targetMethod" value="doBuildIndex" />
<property name="concurrent" value="false" /> <!--将并发设置为false-->
</bean>

<bean id="luceneTimerTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
<property name="jobDetail" ref="luceneTimerMethod" />
<property name="cronExpression" value="0 1/30 * * * ?" /> <!--每30分钟构造一次索引-->
</bean>

整合完成后,控制台下得出测试结果如下:

测试定时器,总计数:1
当前时间:2009-08-11 16:37:00
---------------------------------
测试定时器,总计数:2
当前时间:2009-08-11 16:40:00
---------------------------------
测试定时器,总计数:3
当前时间:2009-08-11 16:43:00
---------------------------------
测试定时器,总计数:4
当前时间:2009-08-11 16:46:00
---------------------------------
测试定时器,总计数:5
当前时间:2009-08-11 16:49:00
---------------------------------
测试定时器,总计数:6
当前时间:2009-08-11 16:52:00
---------------------------------

这样,一个简单的例子完成了!

最后,附:cronExpression配置说明


字段 允许值 允许的特殊字符
秒 0-59 , - * /
分 0-59 , - * /
小时 0-23 , - * /
日期 1-31 , - * ? / L W C
月份 1-12 或者 JAN-DEC , - * /
星期 1-7 或者 SUN-SAT , - * ? / L C #
年(可选) 留空, 1970-2099 , - * /
表达式 意义
"0 0 12 * * ?" 每天中午12点触发
"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点到下午2:59期间的每1分钟触发
"0 0/5 14 * * ?" 在每天下午2点到下午2:55期间的每5分钟触发
"0 0/5 14,18 * * ?" 在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发
"0 0-5 14 * * ?" 在每天下午2点到下午2:05期间的每1分钟触发
"0 10,44 14 ? 3 WED" 每年三月的星期三的下午2:10和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年至2005年的每月的最后一个星期五上午10:15触发
"0 15 10 ? * 6#3" 每月的第三个星期五上午10:15触发
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值