spring 定时器

spring 定时器
先来看配置文件
<?xml version="1.0" encoding="UTF-8"?>




<bean id="sayHelloJob" class="org.springframework.scheduling.quartz.JobDetailBean">

<property name="jobClass">

<value>test.timerTask.SayHelloTaskUsingQuartz</value>

</property>

</bean>

<!-- 关键在如下两个触发器的配置 -->

<!-- 类似于Java的简单触发器 -->

<bean id="helloTrigger" class="org.springframework.scheduling.quartz.SimpleTriggerBean">


<property name="jobDetail">

<ref bean="sayHelloJob"/>

</property>

<property name="startDelay">

<value>1000</value>

</property>

<property name="repeatInterval">

<value>3000</value>

</property>

</bean>

<!-- 复杂触发器 -->

<bean id="helloCronTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">


<property name="jobDetail">

<ref bean="sayHelloJob"/>

</property>

<property name="cronExpression">

<!-- 关键在配置此表达式 -->

<value>0 49 15 * * ?</value>

</property>

</bean>


<bean id="scheduler" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">

<property name="triggers">

<ref bean="helloCronTrigger"/>

</property>

</bean>



当有任务触发时,spring会去调用quartzJob的execute()方法,在这个方法里我们就可以写一些我们自己的业务操作。

上面只是说了定时和任务出发时的处理,下面再看看如何动态的添加定时任务

package com.actmaps.scheduler;

import java.text.ParseException;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.quartz.CronTrigger;
import org.quartz.Scheduler;
import org.quartz.SchedulerException;
import org.quartz.SimpleTrigger;
import org.quartz.impl.StdSchedulerFactory;

/**
* TODO 设置定时任务的控制类
* @author PHeH<br>
* Created On 16:11:24
*/
public class Schedule{

/**
* TODO 添加一个新的触发器
* @return
* @author PHeH<br>
* Created On 2006-6-9 16:24:54
*/
public boolean insertTrigger()
{
try {
Scheduler scheduler = (Scheduler) StdSchedulerFactory.getDefaultScheduler( );
CronTrigger newCronTrigger = new CronTrigger();
try {
newCronTrigger.setName("newCronTrigger");
newCronTrigger.setCronExpression(this.formatQuartzString());
newCronTrigger.setJobName("quartzJob");
} catch (ParseException e) {
e.printStackTrace();
log.error("解析触发器字符串格式出错:"+e.getMessage());
}
scheduler.scheduleJob(newCronTrigger);
} catch (SchedulerException e1) {
e1.printStackTrace();
log.error("添加新触发器时发生SchedulerException异常:"+e1.getMessage());
}
return false;
}

}

对于复杂触发器的cronExpression,可借鉴linux的cron。

关于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触发
每天早上6点

0 6 * * *

每两个小时

0 */2 * * *
晚上11点到早上8点之间每两个小时,早上八点

0 23-7/2,8 * * *

每个月的4号和每个礼拜的礼拜一到礼拜三的早上11点

0 11 4 * 1-3
1月1日早上4点

0 4 1 1 *

</beans>

这里的JobDetail使用的是JobDetailBean,这样直接实例化test.timerTask.SayHelloTaskUsingQuartz。它存在一个问题,当test.timerTask.SayHelloTaskUsingQuartz需要使用依赖注入时,显然,这样直接实例化是没法进行注入的。spring还提供了另一种方法,如下

<bean id="quartzJob" class="com.actmaps.scheduler.QuartzJob">
<property name="reminderControl">
<ref bean="reminder"/>
</property>
</bean>
<bean id="methodInvokingJobDetail" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<property name="targetObject">
<ref bean="quartzJob"/>
</property>
<property name="targetMethod">
<value>execute</value>
</property>
</bean>


<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "spring-beans.dtd" >




<beans>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值