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 = "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
?
源自:http://www.blogjava.net/super2/archive/2007/04/18/111703.html
?
?
字段?允许值?允许的特殊字符?
秒?0-59?,?-?*?/?
分?0-59?,?-?*?/?
小时?0-23?,?-?*?/?
日期?1-31?,?-?*???/?L?W?C?
月份?1-12?或者?JAN-DEC?,?-?*?/?
星期?1-7?或者?SUN-SAT?,?-?*???/?L?C?#?
年(可选)?留空,?1970-2099?,?-?*?/?
表达式?意义?
"0?0?12?*?*??"?每天中午12点触发?
"0?15?10???*?*"?每天上午10:15触发?
"0?15?10?*?*??"?每天上午10:15触发?
"0?15?10?*?*???*"?每天上午10:15触发?
"0?15?10?*?*???2005"?2005年的每天上午10:15触发?
"0?*?14?*?*??"?在每天下午2点到下午2:59期间的每1分钟触发?
"0?0/5?14?*?*??"?在每天下午2点到下午2:55期间的每5分钟触发?
"0?0/5?14,18?*?*??"?在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发?
"0?0-5?14?*?*??"?在每天下午2点到下午2:05期间的每1分钟触发?
"0?10,44?14???3?WED"?每年三月的星期三的下午2:10和2:44触发?
"0?15?10???*?MON-FRI"?周一至周五的上午10:15触发?
"0?15?10?15?*??"?每月15日上午10:15触发?
"0?15?10?L?*??"?每月最后一日的上午10:15触发?
"0?15?10???*?6L"?每月的最后一个星期五上午10:15触发?
"0?15?10???*?6L?2002-2005"?2002年至2005年的每月的最后一个星期五上午10:15触发?
"0?15?10???*?6#3"?每月的第三个星期五上午10:15触发?
===============================================================================
秒(0~59)
分钟(0~59)
小时(0~23)
天(月)(0~31,但是你需要考虑你月的天数)
月(0~11)
天(星期)(1~7?1=SUN?或?SUN,MON,TUE,WED,THU,FRI,SAT)
?
一个完整的例子
“0?0?12???*?WED”表示每个星期三中午12点
?
有些子表达式能包含一些范围或列表
例如:子表达式(天(星期))可以为?“MON-FRI”,“MON,WED,FRI”,“MON-WED,SAT”
?
“*”字符代表所有可能的值
因此,“*”在子表达式(月)里表示每个月的含义,“*”在子表达式(天(星期))表示星期的每一天
?
“/”字符用来指定数值的增量
例如:在子表达式(分钟)里的“0/15”表示从第0分钟开始,每15分钟
?????????在子表达式(分钟)里的“3/20”表示从第3分钟开始,每20分钟(它和“3,23,43”)的含义一样
?
“?”字符仅被用于天(月)和天(星期)两个子表达式,表示不指定值
当2个子表达式其中之一被指定了值以后,为了避免冲突,需要将另一个子表达式的值设为“?”
?
“L”?字符仅被用于天(月)和天(星期)两个子表达式,它是单词“last”的缩写
但是它在两个子表达式里的含义是不同的。
在天(月)子表达式中,“L”表示一个月的最后一天
在天(星期)自表达式中,“L”表示一个星期的最后一天,也就是SAT
如果在“L”前有具体的内容,它就具有其他的含义了
例如:“6L”表示这个月的倒数第6天,“FRIL”表示这个月的最一个星期五
注意:在使用“L”参数时,不要指定列表或范围,因为这会导致问题
?
?
?
?