Quartz与spring2.0集成备忘录

经过一段时间的查找资料和试验,发现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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值