用Quartz处理定时执行的任务-步骤

来源:互联网 发布:传智软件科技有限公司 编辑:程序博客网 时间:2024/06/06 15:43
在Spring中,使用JDK的Timer类库来做任务调度功能不是很方便,关键它不可以象cron服务那样可以指定具体年、月、日、时和分的时间。你只能将时间通过换算成微秒后传给它。如任务是每天执行一次,则需要在spring中如下配置:
<bean id="scheduledTask" class= "org.springframework.scheduling.timer.ScheduledTimerTask">
<!--程序启动后开始执行任务的延迟时间 -->
<property name="delay" value="0" />
<!--每隔一天【一天=24×60×60×1000微秒】执行一次-->
<property name="period" value="86400000" />
<!--业务统计报表bean -->
<property name="timerTask" ref="businessReport" />
</bean>
其中period就是一天的微秒数。如果每月1日运行一次,那就复杂了,不知如何配置。因为月份有大、小月之分,每月的微秒数都不一样。
而Quartz类库不但有着上述JDK的Timer类库类似的配置,更重要的,它还有着类似于unix的cron服务的配置。因此,在迁移中我们采用了Quartz类库的接口。

下面,一起来看看怎么通过quartz实现定时任务:

第一步:引包

  要使用Quartz,必须要引入以下这几个包:

  1、log4j-1.2.16

  2、quartz-2.1.7

  3、slf4j-api-1.6.1.jar

  4、slf4j-log4j12-1.6.1.jar

  这些包都在下载的Quartz包里面包含着,因此没有必要为寻找这几个包而头疼。

第二步:创建要被定执行的任务类

  这一步也很简单,只需要创建一个实现了org.quartz.Job接口的类,并实现这个接口的唯一一个方法execute(JobExecutionContext arg0) throws JobExecutionException即可。如:

import java.text.SimpleDateFormat;  import java.util.Date;  import org.quartz.Job; import org.quartz.JobExecutionContext; import org.quartz.JobExecutionException;  public class myJob implements Job {      @Override     public void execute(JobExecutionContext arg0) throws JobExecutionException {         SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss SSS");         System.out.println(sdf.format(new Date()));     }  } 

第三步:创建任务调度,并执行

  这一步应该算是最难的一步的,但其实是非常简单的,直接上代码

import static org.quartz.CronScheduleBuilder.cronSchedule; import static org.quartz.JobBuilder.newJob; import static org.quartz.TriggerBuilder.newTrigger;  import java.text.SimpleDateFormat; import java.util.Date;  import org.quartz.CronTrigger; import org.quartz.JobDetail; import org.quartz.Scheduler; import org.quartz.SchedulerFactory; import org.quartz.impl.StdSchedulerFactory;  public class Test {     public void go() throws Exception {         // 首先,必需要取得一个Scheduler的引用       SchedulerFactory sf = new StdSchedulerFactory();         Scheduler sched = sf.getScheduler();         //jobs可以在scheduled的sched.start()方法前被调用                  //job 1将每隔20秒执行一次         JobDetail job = newJob(myJob.class).withIdentity("job1", "group1").build();         CronTrigger trigger = newTrigger().withIdentity("trigger1", "group1").withSchedule(cronSchedule("0/20 * * * * ?")).build();         Date ft = sched.scheduleJob(job, trigger);         SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss SSS");         System.out.println(job.getKey() + " 已被安排执行于: " + sdf.format(ft) + ",并且以如下重复规则重复执行: " + trigger.getCronExpression());          // job 2将每2分钟执行一次(在该分钟的第15秒)         job = newJob(myJob.class).withIdentity("job2", "group1").build();         trigger = newTrigger().withIdentity("trigger2", "group1").withSchedule(cronSchedule("15 0/2 * * * ?")).build();         ft = sched.scheduleJob(job, trigger);        System.out.println(job.getKey() + " 已被安排执行于: " + sdf.format(ft) + ",并且以如下重复规则重复执行: "+ trigger.getCronExpression());                 // 开始执行,start()方法被调用后,计时器就开始工作,计时调度中允许放入N个Job       sched.start();         try {             //主线程等待一分钟             Thread.sleep(60L * 1000L);         } catch (Exception e) {}            //关闭定时调度,定时器不再工作        sched.shutdown(true); }      public static void main(String[] args) throws Exception {          Test test = new Test();         test.go();     }  } 
OK了,Job1和Job2就会被安排为定时执行了。此时程序是可以执行的了,但是可能会输出WARN级别日志,这是因为没有加log4j的配置文件,加上配置文件,就OK了。这里需要说明的地方只有一个,其它的可以直接Copy到您的项目里面。看代码:
  1. CronTrigger trigger = newTrigger().withIdentity("trigger1", "group1").withSchedule(cronSchedule("0/20 * * * * ?")).build(); 
 "0/20 * * * * ?"代表什么?这是关键,想搞明白这个,请参考另外一篇博客:http://blog.csdn.net/miss_kun/article/details/51614703


0 0
原创粉丝点击