Quartz与spring2.0集成备忘录
2010-09-15 11:28
309 查看
经过一段时间的查找资料和试验,发现Quartz与spring2.0集成比较简单,在此做下记录,方便以后查找。
新建web工程如图所示:
第一步:新建个类TaskService并添加个方法execute,只是个普通的JavaBean;
TaskService.java
package com.go.task;
import java.io.IOException;
import java.util.Date;
import org.apache.log4j.Logger;
public class TaskService {
Logger logger = Logger.getLogger(TaskService.class);
public void execute() {
String command = "xcopy D://work//mms_web//WebRoot//XMLData c://Media /s";
try {
Runtime.getRuntime().exec(command);
} catch (IOException e) {
logger.error(e);
}
logger.info(new Date() + " 任务执行中 " + command);
}
}
第二步:导入Quartz和spring2.0的jar包,以及log4j的包;
第三步:在web.xml中增加初始化sping的配置信息;
web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<!--
********************************************************************
初始化Spring web 上下文
-->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/classes/applicationContext.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>
第四步:在src下添加sping和log4j的配置文件,并增加相应配置信息;
applicationContext.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
xmlns:jee="http://www.springframework.org/schema/jee"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.0.xsd
http://www.springframework.org/schema/jee
http://www.springframework.org/schema/jee/spring-jee-2.0.xsd">
<!-- 定时器需要执行的代码-->
<bean id="taskService" class="com.go.task.TaskService"></bean>
<!-- 定时器执行 -->
<bean id="job"
class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<property name="triggers">
<list>
<ref bean="jobTriggers" />
</list>
</property>
</bean>
<!--设定执行代码中的具休方法-->
<bean id="jobDetails"
class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<property name="targetObject">
<ref bean="taskService" />
</property>
<property name="targetMethod">
<value>execute</value>
</property>
</bean>
<!-- 定时器时间与方法的设定 -->
<bean id="jobTriggers" class="org.springframework.scheduling.quartz.CronTriggerBean">
<property name="jobDetail">
<ref bean="jobDetails" />
</property>
<property name="cronExpression">
<value>0 * * * * ?</value>
</property>
</bean>
</beans>
log4j.properties
log4j.rootCategory=INFO,stdout,fileout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=[%d LV:%5p CL:%c%t] %m%n
#log4j.appender.fileout.encoding=UTF-8
log4j.appender.fileout=org.apache.log4j.RollingFileAppender
log4j.appender.fileout.File=D/://workarea//log.log
log4j.appender.fileout.MaxFileSize=5MB
log4j.appender.fileout.MaxBackupIndex=100
log4j.appender.fileout.Append=true
log4j.appender.fileout.layout=org.apache.log4j.PatternLayout
log4j.appender.fileout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss.SSS} %-5p [%C.%M():%L] %m%n
新建web工程如图所示:
第一步:新建个类TaskService并添加个方法execute,只是个普通的JavaBean;
TaskService.java
package com.go.task;
import java.io.IOException;
import java.util.Date;
import org.apache.log4j.Logger;
public class TaskService {
Logger logger = Logger.getLogger(TaskService.class);
public void execute() {
String command = "xcopy D://work//mms_web//WebRoot//XMLData c://Media /s";
try {
Runtime.getRuntime().exec(command);
} catch (IOException e) {
logger.error(e);
}
logger.info(new Date() + " 任务执行中 " + command);
}
}
第二步:导入Quartz和spring2.0的jar包,以及log4j的包;
第三步:在web.xml中增加初始化sping的配置信息;
web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<!--
********************************************************************
初始化Spring web 上下文
-->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/classes/applicationContext.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>
第四步:在src下添加sping和log4j的配置文件,并增加相应配置信息;
applicationContext.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
xmlns:jee="http://www.springframework.org/schema/jee"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.0.xsd
http://www.springframework.org/schema/jee
http://www.springframework.org/schema/jee/spring-jee-2.0.xsd">
<!-- 定时器需要执行的代码-->
<bean id="taskService" class="com.go.task.TaskService"></bean>
<!-- 定时器执行 -->
<bean id="job"
class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<property name="triggers">
<list>
<ref bean="jobTriggers" />
</list>
</property>
</bean>
<!--设定执行代码中的具休方法-->
<bean id="jobDetails"
class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<property name="targetObject">
<ref bean="taskService" />
</property>
<property name="targetMethod">
<value>execute</value>
</property>
</bean>
<!-- 定时器时间与方法的设定 -->
<bean id="jobTriggers" class="org.springframework.scheduling.quartz.CronTriggerBean">
<property name="jobDetail">
<ref bean="jobDetails" />
</property>
<property name="cronExpression">
<value>0 * * * * ?</value>
</property>
</bean>
</beans>
log4j.properties
log4j.rootCategory=INFO,stdout,fileout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=[%d LV:%5p CL:%c%t] %m%n
#log4j.appender.fileout.encoding=UTF-8
log4j.appender.fileout=org.apache.log4j.RollingFileAppender
log4j.appender.fileout.File=D/://workarea//log.log
log4j.appender.fileout.MaxFileSize=5MB
log4j.appender.fileout.MaxBackupIndex=100
log4j.appender.fileout.Append=true
log4j.appender.fileout.layout=org.apache.log4j.PatternLayout
log4j.appender.fileout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss.SSS} %-5p [%C.%M():%L] %m%n
相关文章推荐
- spring boot 集成quartz 2.0 实现前端动态配置(获取spring上下文)的两种方式,启动数据库中已开启定时任务
- Spring2.0集成Quartz1.5.2调度框架
- spring boot 集成quartz 2.0 实现前端动态配置(获取spring上下文)的两种方式,启动数据库中已开启定时任务
- spring2.0 集成 quartz 问题解决方案
- spring内集成quartz
- Spring集成Quartz定时任务框架介绍和Cron表达式详解
- Spring-3.2.4 + Quartz-2.2.0集成实例
- (十七)Spring 集成Quartz
- spring集成quartz会重复调用2次的问题
- spring集成并配制quartz
- Quartz与Spring集成——创建调度器 定时
- Spring集成Quartz定时任务框架介绍和Cron表达式详解
- Spring集成Quartz
- spring 3.0集成 quartz
- Spring+SpringMVC+Mybatis框架集成Apache CXF2.7集成 mongodb集成quartz
- Spring与Quartz集成详解
- Spring 与 Quartz 集成事务
- Quartz与Spring集成
- Spring Boot集成持久化Quartz定时任务管理和界面展示
- Quartz集成Spring