Spring定时器(Quartz定时调度任务用)
//一、JAVA/
创建一个类,类中方法doAuth(),对这个方法进行触发
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("开始进行任务调度,验证信息:");
}
}
//二、Spring配置文件JobQuartz.xml /
对应的xml,名字JobQuartz.xml [18点的每一分,每一秒都进行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"> <!-- targetObject是Spring定时器的特殊属性 -->
<ref local="job"/>
</property>
<property name="targetMethod"> <!-- targetMethod是Spring定时器的特殊属性 -->
<value>doAuth</value><!-- 这里的doAuth 就是java类中的任务方法-->
</property>
</bean>
<!-- 定义触发的时间 -->
<bean id = "cron" class = "org.springframework.scheduling.quartz.CronTriggerBean">
<property name="jobDetail"> <!-- jobDetail是Spring定时器的特殊属性 -->
<ref bean="jobtask"/>
</property>
<property name="cronExpression"> <!-- cronExpression是Spring定时器的特殊属性 -->
<value>* * 18 * * ?</value>
</property>
</bean>
<!-- 总管理 -->
<bean autowire = "no" class = "org.springframework.scheduling.quartz.SchedulerFactoryBean">
<property name="triggers"> <!-- triggers是Spring定时器的特殊属性 -->
<list>
<ref local ="cron"/>
</list>
</property>
</bean>
</beans>
//三、加载Spring配置文件/
进行测试,只要加载JobQuartz.xml
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("测试结束");
}
}
//四、导入需要的.jar包/
需要加入以下6个包
1、spring.jar
2、quartz-all-1.6.0.jar
3、log4j-1.2.14.jar
4、commons-collections.jar
5、jta.jar
6、commons-logging.jar
//五、配置日志文件
以下是log4j.properties内容
# 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