Spring Quartz任务调度示例

package  com.xzl.quartz;

import  org.apache.log4j.Logger;



public   class  TJob  {
    
private Logger logger = Logger.getLogger(this.getClass().getName());
    
public void doAuth(){
        logger.info(
"开始进行任务调度,验证信息:");
    }

}

1.创建一个类,类中方法doAuth(),对这个方法进行触发

<? xml version="1.0" encoding="UTF-8" ?>
<! DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd" >

< beans >
<!-- 要调度的对象 -->

    
< bean  id ="job"  class ="com.xzl.quartz.TJob" ></ bean >
<!--  定义目标bean和bean中的方法  -->
    
< bean  id ="jobtask"  class ="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean" >
        
< property  name ="targetObject" >
            
< ref  local ="job" />
        
</ property >
        
< property  name ="targetMethod" >
            
< value > doAuth </ value >
        
</ property >
    
</ bean >
<!--  定义触发的时间  -->
    
< bean  id  = "cron"  class  = "org.springframework.scheduling.quartz.CronTriggerBean" >
        
< property  name ="jobDetail" >
            
< ref  bean ="jobtask" />
        
</ property >
        
< property  name ="cronExpression" >
            
< value > * * 18 * * ? </ value >
        
</ property >
    
</ bean >
<!--  总管理  -->
    
< bean  autowire  = "no"  class  = "org.springframework.scheduling.quartz.SchedulerFactoryBean" >
        
< property  name ="triggers" >
            
< list >
                
< ref  local  ="cron" />
            
</ list >
        
</ property >
    
</ bean >

</ beans >

2.对应的xml,名字JobQuartz.xml   [18点的每一分,每一秒都进行doAuth()方法的触发]

package  com.xzl.quartz;

import  org.springframework.context.ApplicationContext;
import  org.springframework.context.support.ClassPathXmlApplicationContext;


public   class  Test  {
    
    
/** *//**
     * 
@param args
     
*/

    
public static void main(String[] args) {
        
// TODO Auto-generated method stub
        
        System.out.println(
"测试开始");
        ApplicationContext ctx 
= new ClassPathXmlApplicationContext("JobQuartz.xml");
        System.out.println(
"测试结束");
        
    }


}

3.进行测试,只要加载JobQuartz.xml
4.需要加入spring.jar   quartz-all-1.6.0.jar   log4j-1.2.14.jar   commons-collections.jar   jta.jar   commons-logging.jar这几个包
# For JBoss: Avoid to setup Log4J outside $JBOSS_HOME/server/default/deploy/log4j.xml!
# For all other servers: Comment out the Log4J listener in web.xml to activate Log4J.
log4j.rootLogger=INFO, stdout, logfile

log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d %p [%c] - <%m>%n

log4j.appender.logfile=org.apache.log4j.RollingFileAppender
log4j.appender.logfile.File=logs\\test.log
log4j.appender.logfile.MaxFileSize=512KB
# Keep three backup files.
log4j.appender.logfile.MaxBackupIndex=3
# Pattern to output: date priority [category] - message
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=%d %p [%c] - %m%n

5.以上是log4j.properties内容

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值