Spring 3.1 任务调度

来源:互联网 发布:英雄杀礼包软件 编辑:程序博客网 时间:2024/06/05 04:10

Spring 3.1 任务调度

 
名称空间: 
http://www.springframework.org/schema/task 
XSD location: 
http://www.springframework.org/schema/task/spring-task-3.0.xsd 

任务调度器配置: 
task:scheduler/@pool-size:调度线程池的大小,调度线程在被调度任务完成前不会空闲 
task:scheduled/@cron:cron表达式,注意,若上次任务未完成,即使到了下一次调度时间,任务也不会重复调度
Xml代码  收藏代码
  1. <task:scheduled-tasks scheduler="scheduler">  
  2.     <task:scheduled ref="beanID" method="methodName" cron="CronExp" />  
  3. </task:scheduled-tasks>  
  4. <task:scheduler id="scheduler" pool-size="1" />  

Spring3.0以后,自己已经完全支持更加精确的时间,而不需要Quartz的支持:当然后面我们也会用Quartz实现任务的调度。

Spring3.0同样也使用cron表达式。与Quartz不同的是,Spring3.0不支持年,而Quartz支持年。但这点好象并不是非常重要。

cron表达式:-是用空格分开的时间字段,不使用年。

*(秒0-59)    *(分钟0-59)   *(小时0-23)  *(日期1-31)   *(月份1-12或是JAN-DEC)  *(星期1-7或是SUN-SAT)  

示例:
*/5  * * * * 6-7  :: 每个周6到周日,每隔5秒钟执行一次。

*/1 * * 7-9 1-2 1-7 :: 1月到2月中的7号到9号,且必须要满足周一到周日,每隔1秒钟执行一次。

*/1 * * 7-9 1,5 1-7  :: 注意里面的,(逗号),只有1月和5月的7到9号,且必须要满足周一到周日,每一秒钟执行一次。

*/1 17-59 * 7-9 1,5 1-7 :: 只解释17-59,是指从第17分钟到第59分钟,在指定的时间内,每一秒种执行一次
* 17-59 * 7-9 1,5 1-7   :: 此代码的功能与上面完全相同。如果不写秒即为每一秒执行一次。


59 19-23 * 7-9 1,5 1-7  :: 19分-23分的每59秒钟时只执行一次。

59 19,26 * 7-9 1,5 1-7  :: 注意里面的,(逗号),是指只有19分或是26分的56秒钟时执行一次。

* * 16-23 7-9 1,5 1-7   :: 定义每天的16点到23点每一秒钟执行一次。


59 59 23 * * 1-5  :: 定义每周1到周5,晚上23:59:59秒只执行一次。这个相当用有。可以工作时间每天给用户发邮件。

在Spring3.0中引用了新的命名空间-task:

task:scheduler 用于定义一个ThreadPoolTaskScheduler,并可以指定线程池的大小,即pool-size.所有任务队列都将会在指定大小的线程池中运行:
定义如下:
<!-- 对于同一个Pojo可以声明多次,并设置标记属性 --> 
<bean id="one" class="cn.itcast.schedule.One">
<property name="task" value="A"></property>
</bean>
<bean id="two" class="cn.itcast.schedule.One">
<property name="task" value="B"></property>
</bean>
<bean id="three" class="cn.itcast.schedule.One">
<property name="task" value="C"></property>
</bean>
<!-- 声明一个具有两个线程的池,每一个对象将获取同样的运行机会 -->
<task:scheduler id="sch" pool-size="2"/>
<!-- 引用线程池 -->
<task:scheduled-tasks scheduler="sch">
<!-- 引用Spring Bean并设置调用的方法的时间间隔 -->
<task:scheduled ref="one" method="doSomeThing"  fixed-delay="#{1000*3}"/>
<task:scheduled ref="two" method="doSomeThing"  fixed-delay="#{1000*3}"/>
<task:scheduled ref="three" method="doSomeThing"  fixed-delay="#{1000*3}"/>
</task:scheduled-tasks> 
<!-- 配置一个定时执行的任务 -->
<bean id="work" class="cn.itcast.schedule.Two"/>
<task:scheduler id="sendMail"/>
<task:scheduled-tasks scheduler="sendMail">
<!-- 定义在1月8号19:37:1秒执行一次,无论是周几 -->
<task:scheduled ref="work" method="work" cron="1 37 19 8 1 *"/>
</task:scheduled-tasks>

定义好之后,正常启动容器即可,只有条件符合,即会按要求执行任务。

任务执行器配置: 
task:executor/@pool-size:可以指定执行线程池的初始大小、最大大小 
task:executor/@queue-capacity:等待执行的任务队列的容量 
task:executor/@rejection-policy:当等待队列爆了时的策略,分为丢弃、由任务执行器直接运行等方式 
Xml代码  收藏代码
  1. <task:executor id="executor" keep-alive="3600" pool-size="100-200" queue-capacity="500" rejection-policy="CALLER_RUNS" />  
0 0