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内容

你可能感兴趣的:(apache,spring,log4j,bean,quartz)