Spring + Quartz任务调度实战之动态作业调度

               

本文地址:http://blog.csdn.net/kongxx/article/details/6860732

前面写了几个文章是关于spring中集成作业调度功能的东西,可以参考

Spring任务调度实战之Timer

Spring任务调度实战之Quartz Simple Trigger

Spring任务调度实战之Quartz Cron Trigger

但那些例子都是对静态作业做调度的例子,这里所谓静态作业都是指作业信息和调度信息是写死在spring的配置文件中的,但是真实很多应用的情况都是需要动态的对作业进行调度,比如动态添加或者删除作业,动态的设置作业的trigger等。下面就来看看在spring中怎样实现对动态作业进行调度。

1. 首先是一个任务类,这个类没有实现任何接口,其中包含一个run方法用来运行这个task,代码如下:

package org.garbagecan.springstudy.schedule.quartz;public class MyTask private String name;  public void run() {  System.out.println("Run task: " + name + "."); } public String getName() {  return name; } public void setName(String name) {  this.name = name; }}
2. 一个Job类,这个类需要继承spring的QuartzJobBean类,来说明当前类是一个Quartz的Job类,类包含了一个Task类的对象实例,在每次Job被调度的时候,将会运行其中的executeInternal方法,代码如下:

package org.garbagecan.springstudy.schedule.quartz;import org.quartz.JobExecutionContext;import org.quartz.JobExecutionException;import org.springframework.scheduling.quartz.QuartzJobBean;public class MyJob extends QuartzJobBean {  private MyTask myTask; protected void executeInternal(JobExecutionContext context)   throws JobExecutionException {    myTask.run(); } public MyTask getMyTask() {  return myTask; } public void setMyTask(MyTask myTask) {  this.myTask = myTask; }}
3. Spring配置文件,内容如下

<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd"       default-lazy-init="true"> <bean id="scheduler" class="org.springframework.scheduling.quartz.SchedulerFactoryBean" lazy-init="false">  <property name="triggers">   <list>   </list>  </property> </bean></beans>
配置中仅仅配置了一个schedule类的实例,其中的triggers的列表为空。这样在这个schedule启动的时候就不会schedule任何作业。

4. 最后,写一个测试类来测试上面的代码和配置

package org.garbagecan.springstudy.schedule.dynamic;import org.quartz.CronTrigger;import org.quartz.JobDetail;import org.quartz.Scheduler;import org.quartz.SchedulerException;import org.springframework.context.ApplicationContext;import org.springframework.context.support.ClassPathXmlApplicationContext;import java.text.ParseException;public class Test public static void main(String[] args) {  ApplicationContext ctx = new ClassPathXmlApplicationContext("/org/garbagecan/springstudy/schedule/dynamic/spring.xml");  Scheduler scheduler = (Scheduler)ctx.getBean("scheduler");  System.out.println("Scheduling to run tasks.");  for (int i = 0; i < 5; i++) {   try {    JobDetail jobDetail = new JobDetail();    jobDetail.setName("job_" + i);    MyTask myTask = new MyTask();    myTask.setName("task_" + i);    jobDetail.getJobDataMap().put("myTask", myTask);    jobDetail.setJobClass(MyJob.class);    scheduler.addJob(jobDetail, true);    CronTrigger cronTrigger =new CronTrigger("cron_" + i, Scheduler.DEFAULT_GROUP, jobDetail.getName(), Scheduler.DEFAULT_GROUP);    cronTrigger.setCronExpression("0/10 * * * * ?");    scheduler.scheduleJob(cronTrigger);   } catch (ParseException e) {    e.printStackTrace();   } catch (SchedulerException e) {    e.printStackTrace();   }  }  try {   Thread.sleep(60 * 1000);  } catch (InterruptedException e) {   e.printStackTrace();  }  System.out.println("Un-scheduling to run tasks.");  for (int i = 0; i < 5; i++) {   try {    scheduler.unscheduleJob("cron_" + i, Scheduler.DEFAULT_GROUP);   } catch (SchedulerException e) {    e.printStackTrace();   }  } }}
4.1 测试类首先创建了5个JobDetail和CronTrigger,每个JobDetail对应一个我们的MyJob和MyTask类实例,每个CronTrigger都是10秒钟运行一次的cron表达式。具体的API可以参考Quartz的官方文档;
4.2 对于每个创建的JobDetail和CronTrigger,都使用Quartz的Scheduler去做调度;
4.3 等待60秒,让上面创建的那些作业运行几次,此时在后台可以看到有message输出;
4.4 Un-schedule上面创建的JobDetail和CronTrigger,此段代码之后,所有的作业都被停止了。















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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值