Spring定时任务的几种实现.docx
《Spring定时任务的几种实现.docx》由会员分享,可在线阅读,更多相关《Spring定时任务的几种实现.docx(20页珍藏版)》请在冰点文库上搜索。
Spring定时任务的几种实现
Spring定时任务的几种实现
近日项目开发中需要执行一些定时任务,比如需要在每天凌晨时候,分析一次前一天的日志信息,借此机会整理了一下定时任务的几种实现方式,由于项目采用spring框架,所以我都将结合
spring框架来介绍。
一.分类
∙从实现的技术上来分类,目前主要有三种技术(或者说有三种产品):
1.Java自带的java.util.Timer类,这个类允许你调度一个java.util.TimerTask任务。
使用这种方式可以让你的程序按照某一个频度执行,但不能在指定时间运行。
一般用的较少,这篇文章将不做详细介绍。
2.使用Quartz,这是一个功能比较强大的的调度器,可以让你的程序在指定时间执行,也可以按照某一个频度执行,配置起来稍显复杂,稍后会详细介绍。
3.Spring3.0以后自带的task,可以将它看成一个轻量级的Quartz,而且使用起来比Quartz简单许多,稍后会介绍。
∙从作业类的继承方式来讲,可以分为两类:
1.作业类需要继承自特定的作业类基类,如Quartz中需要继承自org.springframework.scheduling.quartz.QuartzJobBean;java.util.Timer中需要继承自java.util.TimerTask。
2.作业类即普通的java类,不需要继承自任何基类。
注:
个人推荐使用第二种方式,因为这样所以的类都是普通类,不需要事先区别对待。
∙从任务调度的触发时机来分,这里主要是针对作业使用的触发器,主要有以下两种:
1.每隔指定时间则触发一次,在Quartz中对应的触发器为:
org.springframework.scheduling.quartz.SimpleTriggerBean
2.每到指定时间则触发一次,在Quartz中对应的调度器为:
org.springframework.scheduling.quartz.CronTriggerBean
注:
并非每种任务都可以使用这两种触发器,如java.util.TimerTask任务就只能使用第一种。
Quartz和springtask都可以支持这两种触发条件。
二.用法说明
详细介绍每种任务调度工具的使用方式,包括Quartz和springtask两种。
Quartz
第一种,作业类继承自特定的基类:
org.springframework.scheduling.quartz.QuartzJobBean。
第一步:
定义作业类
Java代码
1.importorg.quartz.JobExecutionContext;
2.importorg.quartz.JobExecutionException;
3.importorg.springframework.scheduling.quartz.QuartzJobBean;
4.publicclassJob1extendsQuartzJobBean{
5.
6.privateinttimeout;
7.privatestaticinti=0;
8.//调度工厂实例化后,经过timeout时间开始执行调度
9.publicvoidsetTimeout(inttimeout){
10.this.timeout=timeout;
11.}
12.
13./**
14.*要调度的具体任务
15.*/
16.@Override
17.protectedvoidexecuteInternal(JobExecutionContextcontext)
18.throwsJobExecutionException{
19.System.out.println("定时任务执行中…");
20.}
21.}
importorg.quartz.JobExecutionContext;
importorg.quartz.JobExecutionException;
importorg.springframework.scheduling.quartz.QuartzJobBean;
publicclassJob1extendsQuartzJobBean{
privateinttimeout;
privatestaticinti=0;
//调度工厂实例化后,经过timeout时间开始执行调度
publicvoidsetTimeout(inttimeout){
this.timeout=timeout;
}
/**
*要调度的具体任务
*/
@Override
protectedvoidexecuteInternal(JobExecutionContextcontext)
throwsJobExecutionException{
System.out.println("定时任务执行中…");
}
}
第二步:
spring配置文件中配置作业类JobDetailBean
Xml代码
1.
2.
3.
4.
5.
6.
7.
8.
说明:
org.springframework.scheduling.quartz.JobDetailBean有两个属性,jobClass属性即我们在java代码中定义的任务类,jobDataAsMap属性即该任务类中需要注入的属性值。
第三步:
配置作业调度的触发方式(触发器)
Quartz的作业触发器有两种,分别是
org.springframework.scheduling.quartz.SimpleTriggerBean
org.springframework.scheduling.quartz.CronTriggerBean
第一种SimpleTriggerBean,只支持按照一定频度调用任务,如每隔30分钟运行一次。
配置方式如下:
Xml代码
1.
2.
3.
--调度工厂实例化后,经过0秒开始执行调度-->
4.
--每2秒调度一次-->
5.
--调度工厂实例化后,经过0秒开始执行调度-->
--每2秒调度一次-->
第二种CronTriggerBean,支持到指定时间运行一次,如每天12:
00运行一次等。
配置方式如下:
Xml代码
1.
2.
3.
—每天12:
00运行一次-->
4."/>
5.
—每天12:
00运行一次-->
"/>
关于cronExpression表达式的语法参见附录。
第四步:
配置调度工厂
Xml代码
1.
2.
3.
4.
5.
6.
7.
说明:
该参数指定的就是之前配置的触发器的名字。
第五步:
启动你的应用即可,即将工程部署至tomcat或其他容器。
第二种,作业类不继承特定基类。
Spring能够支持这种方式,归功于两个类:
org.springframework.scheduling.timer.MethodInvokingTimerTaskFactoryBean
org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean
这两个类分别对应spring支持的两种实现任务调度的方式,即前文提到到java自带的timertask方式和Quartz方式。
这里我只写MethodInvokingJobDetailFactoryBean的用法,使用该类的好处是,我们的任务类不再需要继承自任何类,而是普通的pojo。
第一步:
编写任务类
Java代码
1.publicclassJob2{
2.publicvoiddoJob2(){
3.System.out.println("不继承QuartzJobBean方式-调度进行中...");
4.}
5.}
publicclassJob2{
publicvoiddoJob2(){
System.out.println("不继承QuartzJobBean方式-调度进行中...");
}
}
可以看出,这就是一个普通的类,并且有一个方法。
第二步:
配置作业类
Xml代码
1.2.class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
3.
4.
5.
6.
7.
--作业不并发调度-->
8.
class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
--作业不并发调度-->
说明:
这一步是关键步骤,声明一个MethodInvokingJobDetailFactoryBean,有两个关键属性:
targetObject指定任务类,targetMethod指定运行的方法。
往下的步骤就与方法一相同了,为了完整,同样贴出。
第三步:
配置作业调度的触发方式(触发器)
Quartz的作业触发器有两种,分别是
org.springframework.scheduling.quartz.SimpleTriggerBean
org.springframework.scheduling.quartz.CronTriggerBean
第一种SimpleTriggerBean,只支持按照一定频度调用任务,如每隔30分钟运行一次。
配置方式如下:
Xml代码
1.
2.
3.
--调度工厂实例化后,经过0秒开始执行调度-->
4.
--每2秒调度一次-->
5.
--调度工厂实例化后,经过0秒开始执行调度-->
--每2秒调度一次-->
第二种CronTriggerBean,支持到指定时间运行一次,如每天12:
00运行一次等。
配置方式如下:
Xml代码
1.
2.
3.
—每天12:
00运行一次-->
4."/>
5.
—每天12:
00运行一次-->
"/>
以上两种调度方式根据实际情况,任选一种即可。
第四步:
配置调度工厂
Xml代码
1.
2.
3.
4.
5.
6.
7.
说明:
该参数指定的就是之前配置的触发器的名字。
第五步:
启动你的应用即可,即将工程部署至tomcat或其他容器。
到此,spring中Quartz的基本配置就介绍完了,当然了,使用之前,要导入相应的spring的包与Quartz的包,这些就不消多说了。
其实可以看出Quartz的配置看上去还是挺复杂的,没有办法,因为Quartz其实是个重量级的工具,如果我们只是想简单的执行几个简单的定时任务,有没有更简单的工具,有!
请看我第下文Springtask的介绍。
Spring-Task
上节介绍了在Spring中使用Quartz,本文介绍Spring3.0以后自主开发的定时任务工具,springtask,可以将它比作一个轻量级的Quartz,而且使用起来很简单,除spring相关的包外不需要额外的包,而且支持注解和配置文件两种
形式,下面将分别介绍这两种方式。
第一种:
配置文件方式
第一步:
编写作业类
即普通的pojo,如下:
Java代码
1.importorg.springframework.stereotype.Service;
2.@Service
3.publicclassTaskJob{
4.
5.publicvoidjob1(){
6.System.out.println(“任务进行中。
。
。
”);
7.}
8.}
importorg.springframework.stereotype.Service;
@Service
publicclassTaskJob{
publicvoidjob1(){
System.out.println(“任务进行中。
。
。
”);
}
}
第二步:
在spring配置文件头中添加命名空间及描述
Xml代码
1.//www.springframework.org/schema/beans"
2.xmlns:
task="http:
//www.springframework.org/schema/task"
3.。
。
。
。
。
。
4.xsi:
schemaLocation="http:
//www.springframework.org/schema/taskhttp:
//www.springframework.org/schema/task/spring-task-3.0.xsd">
//www.springframework.org/schema/beans"
xmlns:
task="http:
//www.springframework.org/schema/task"
。
。
。
。
。
。
xsi:
schemaLocation="http:
//www.springframework.org/schema/taskhttp:
//www.springframework.org/schema/task/spring-task-3.0.xsd">
第三步:
spring配置文件中设置具体的任务
Xml代码
1.scheduled-tasks>
2.scheduledref="taskJob"method="job1"cron="0****?
"/>
3.
scheduled-tasks>
4.
5.component-scanbase-package="com.gy.mytask"/>
scheduled-tasks>
scheduledref="taskJob"method="job1"cron="0****?
"/>
scheduled-tasks>
component-scanbase-package="com.gy.mytask"/>
说明:
ref参数指定的即任务类,method指定的即需要运行的方法,cron及cronExpression表达式,具体写法这里不介绍了,详情见上篇文章附录。
component-scanbase-package="com.gy.mytask"/>这个配置不消多说了,spring扫描注解用的。
到这里配置就完成了,是不是很简单。
第二种:
使用注解形式
也许我们不想每写一个任务类还要在xml文件中配置下,我们可以使用注解@Scheduled,我们看看源文件中该注解的定义:
Java代码
1.@Target({java.lang.annotation.ElementType.METHOD,java.lang.annotation.ElementType.ANNOTATION_TYPE})
2.@Retention(RetentionPolicy.RUNTIME)
3.@Documented
4.public@interfaceScheduled
5.{
6.publicabs