Spring3整合定时器之Quartz

[size=medium]
说到定时器,一定会想到Timer,但是他只能简单的进行时间单位类似倒计时的功能实现,如果要精确每年每月的日期甚至星期几,那么换算起来就比较麻烦,这里可以用Spring与Quartz整合来完成定时器的实现。
虽然Quartz已经发布了2.X版本,但是Spring3目前只能整合Quartz1.8.5及以下版本。
注意Spring整合Quartz项目必须的JAR包:其中slf4j-api-1.6.4.jar是必须的,因为Quartz1.8.5依赖此日志接口,这里我选用Log4j的日志实现。[/size]
[img]http://dl.iteye.com/upload/attachment/0073/8535/d4e2d604-78b6-3d48-9bf8-d55033a6ea91.jpg[/img]


<beans ....>
<!--要调度的对象 -->
<bean id="sendJob" class="com.chou.quartz.SendJob">
<property name="message" value="20秒过去了,发送短信ing..." />
</bean>

<!--要调度的对象 -->
<bean id="receiveJob" class="com.chou.quartz.ReceiveJob">
<property name="message" value="30秒过去了,接收短信ing..." />
</bean>

<!-- ======================== 调度触发器 ======================== -->
<bean id="sendJobDetail" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<property name="targetObject" ref="sendJob"/>
<property name="targetMethod" value="execute"/>
</bean>
<bean id="sendJobTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
<property name="jobDetail" ref="sendJobDetail"/>
<!-- 定义触发的时间 -->
<property name="cronExpression">
<value>0/20 * * * * ?</value>
</property>
</bean>

<!-- ======================== 调度触发器 ======================== -->
<bean id="receiveJobDetail" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<property name="targetObject" ref="receiveJob"/>
<property name="targetMethod" value="execute"/>
</bean>
<bean id="receiveJobTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
<property name="jobDetail" ref="receiveJobDetail"/>
<!-- 定义触发的时间 -->
<property name="cronExpression">
<value>0/30 * * * * ?</value>
</property>
</bean>

<!-- ======================== 调度工厂 ======================== -->
<bean id="scheduler" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<property name="triggers">
<list>
<ref bean="sendJobTrigger"/>
<ref bean="receiveJobTrigger"/>
</list>
</property>
</bean>

</beans>


public class ReceiveJob {

private static final Log logger = LogFactory.getLog(SendJob.class);

private static int counter = 0;

private String message;

public void setMessage(String message) {
this.message = message;
}

public void execute() {
logger.info(message);
System.out.print("(" + counter++ + ")");
System.out.println("\t\t" + new Date());

}
}


public class SendJob {

private static final Log logger = LogFactory.getLog(SendJob.class);

private static int counter = 0;

private String message;

public void setMessage(String message) {
this.message = message;
}

public void execute() {
logger.info(message);
System.out.print("(" + counter++ + ")");
System.out.println("\t\t" + new Date());
}
}


public static void main(String[] args) {
System.out.println("短信服务启动中...");
ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContext-quartz.xml");
System.out.println("短信服务启动成功");
}


[size=medium]这个是Quartz默认的配置文件,文件名quartz.properties,其实不加也可以:[/size]

#============================================================================
# Configure Main Scheduler Properties
#============================================================================
org.quartz.scheduler.instanceName = DefaultQuartzScheduler
org.quartz.scheduler.instanceId = AUTO
org.quartz.scheduler.rmi.export = false
org.quartz.scheduler.rmi.proxy = false
org.quartz.scheduler.wrapJobExecutionInUserTransaction = false

#============================================================================
# Configure ThreadPool
#============================================================================
#org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount = 10
org.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.OracleDelegate
org.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.Driver
#org.quartz.dataSource.myDS.URL = jdbc:mysql://localhost/test
#org.quartz.dataSource.myDS.user = root
#org.quartz.dataSource.myDS.password = root
#org.quartz.dataSource.myDS.maxConnections = 10

[size=medium][b]关于cronExpression表达式:[/b]
可以参考[url]http://dogstar.iteye.com/blog/116130[/url][/size]

字段 允许值 允许的特殊字符
秒 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 6 * * *" 每天早上6点
"0 */2 * * *"每两个小时
"0 23-7/2,8 * * *" 晚上11点到早上8点之间每两个小时,早上八点
"0 11 4 * 1-3" 每个月的4号和每个礼拜的礼拜一到礼拜三的早上11点
"0 4 1 1 *" 1月1日早上4点
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值