本文地址:http://blog.csdn.net/kongxx/article/details/6751326
在Quartz中除了使用最简单的Simple Trigger以外,也可以使用类似Linux上Cron作业的CronTrigger的方式来运行Job,下面是一个小例子:
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="timerFactory" class="org.springframework.scheduling.quartz.SchedulerFactoryBean" lazy-init="false">
<property name="triggers">
<list>
<ref local=""cronTrigger""/>
</list>
</property>
</bean>
<bean id="cronTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
<property name="jobDetail" ref="myJob"/>
<property name="cronExpression" value="0/10 * * * * ?"></property>
</bean>
<bean id="myJob" class="org.springframework.scheduling.quartz.JobDetailBean">
<property name="name" value="myJob"/>
<property name="group" value="myGroup"/>
<property name="description" value="myJob"/>
<property name="jobClass" value="org.garbagecan.springstudy.schedule.quartz.MyJob"/>
<property name="jobDataAsMap">
<map>
<entry key="myTask" value-ref="myTask" />
</map>
</property>
</bean>
<bean id="myTask" class="org.garbagecan.springstudy.schedule.quartz.MyTask">
<property name="name" value="my task"/>
</bean>
</beans>
3.1 首先,需要定义了一个Task类,具体的任务逻辑可以写在这个类里;
3.2 定义一个JobDetailBean类的bean,这个是为了适应Quartz的JobDetail,其中可以定义name,group,description等信息,这些信息主要是为了和别的作业做区分使用;其中还有一个jobClass属性,定义了使用的是那个Job类实例,这里使用第二步创建的MyJob类;最后定义了一个叫jobDataAsMap的属性,这个属性是Quartz提供的用来传递参数使用的一个Map集合,这些集合里的类会被spring自动注入到目标Job类中;
3.3 创建一个触发器类,这里使用的是Quartz提供的Cron Trigger,在Spring里,使用的是CronTriggerBean来做映射,主要是定义cron表达式,具体可以参考quartz的官方文档,这里定义的是每隔10秒运行一次;当然还有最主要的具体的Job类实例;
3.4 最后定义了一个SchedulerFactoryBean的bean,其中定义了具体要调度那些触发器;
4. 最后,写一个测试类来测试上面的代码和配置
package org.garbagecan.springstudy.schedule.quartz;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class Test {
public static void main(String[] args) throws Exception {
new ClassPathXmlApplicationContext("/org/garbagecan/springstudy/schedule/quartz/spring.xml");
}
}
运行Test类,可以看到一个叫my task的job会启动,并且每隔10秒运行一次。
分享到:
相关推荐
Spring整合任务调度框架Quartz,本文档详细介绍了Spring整合任务调度框架Quartz,希望可以帮助学习者
spring任务调度(Quartz )非常基础,
Spring实现任务调度.ppt Spring实现任务调度_代码演示 quartz-all-1.6.1.jar
任务调度系统基于Quartz.net
TimeTask 与quartz简单用法 Spring中任务调度cronExpression配置说明
Spring Quartz 任务调度实例 可直接运行 可应用服务器启动调用 也可main入口调用 主要用于打jar包用
cmd中运行 ”javar -jar 文件名 “ ,生成可视化窗口,方便 生成和解析Cron;从此怕忘记,再也不求人。
Spring中Quartz任务调度器cronexpression配置说明
Spring+Quartz实现任务调度的小例子.本来不要资源分的,可是CSDN发布资源最低要求填写分值为1分,没办法了。
Quartz Cron页面生成工具,整理好的。 在开发中,常常有一些任务,需要隔一段时间自动执行。 Cron能够满足。
Spring实现任务调度.ppt Spring实现任务调度_代码演示 quartz-all-1.6.1.jar
quartz cron js生成器,可以直接嵌入html代码使用 喜欢点赞
该资源描述了用spring+quartz搭建的环境来管理任务调度的基本配置
里面包含了两个工程项目: 1.Java project工程(含jar包,JDK1.6)。 是spring+quartz的任务调度实例。 2.Java web工程(含jar包,JDK1.7)。 spring+mybatis+quartz任务调度实例
Quartz Cron表达式
Quartz 是个开源的作业调度框架,为在 Java 应用程序中进行作业调度提供了简单却强大的机制。Quartz框架包含了调度器监听、作业和触发器监听。你可以配置作业和触发器监听为全局监听或者是特定于作业和触发器的监听...
spring整合quartz定时任务调度..........
3、调度中心HA(中心式):调度采用中心式设计,“调度中心”基于集群Quartz实现,可保证调度中心HA; 4、执行器HA(分布式):任务分布式执行,任务"执行器"支持集群部署,可保证任务执行HA; 5、任务Failover:...
spring quartz 时间任务调度框架 spring quartz 时间任务调度框架 spring quartz 时间任务调度框架
spring+quartz任务调度代码版