Spring+Quartz定时任务,简单的小例子,新手完全手册

<a href="http://www.ydyrx.com" target="_blank" rel="external nofollow" target="_blank" rel="external nofollow" >www.ydyrx.com</a>

最近公司要用定时任务,自己想着学习并完成任务,百度,google,360,必应,能用的搜索都用了,参差不齐,搞了一整天,也没找到一个好的例子。没办法,励志要写一个给新手用,破解迷茫。

我这里是spring3.1.0+quartz2.1.7 用的持久化方式定时的相关参数存储到数据库里的

首先要引入jar包,

我这边用的是quartz2.1.7  如果maven工程的话是这样的

 

 <dependency>

<groupId>org.quartz-scheduler</groupId>

<artifactId>quartz</artifactId>

<version>2.1.7</version>

</dependency>

jar包就不传了,要是有人需要再说。

写配置文件

spring-quartz.xml

 

Xml代码 
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"  
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.     xsi:schemaLocation="http://www.springframework.org/schema/beans  
  5.     http://www.springframework.org/schema/beans/spring-beans-2.0.xsd">  
  6.     <bean name="openLockJob"  
  7.         class="org.springframework.scheduling.quartz.JobDetailFactoryBean">  
  8.         <property name="jobClass" value="com.asp.rc.service.OpenLockTimerHzOwnerServiceNew" />  
  9.         <property name="durability" value="true"></property>  
  10.     </bean>  
  11.     <bean id="openLock"  
  12.         class="org.springframework.scheduling.quartz.CronTriggerFactoryBean">  
  13.         <property name="jobDetail">  
  14.             <ref bean="openLockJob" />  
  15.         </property>  
  16.         <!-- 设置每天03:00:00秒执行定时器 -->  
  17.         <property name="cronExpression">  
  18.                 <value>0/20 * * * * ?</value>  
  19.         </property>  
  20.     </bean>  
  21.   
  22.   
  23.   
  24.   
  25.     <bean id="schedulerFactoryBean"   
  26.         class="org.springframework.scheduling.quartz.SchedulerFactoryBean"  destroy-method="destroy">  
  27.   
  28.         <property name="triggers">  
  29.             <list>  
  30.                 <ref bean="openLock" />  
  31.             </list>  
  32.         </property>  
  33.         <property name="applicationContextSchedulerContextKey" value="applicationContext" />  
  34.         <property name="configLocation" value="classpath:quartz.properties" />   
  35.     </bean>     
  36.       
  37. </beans>  

 然后是quartz.property

Properties代码 
  1. # Default Properties file for use by StdSchedulerFactory  
  2. # to create a Quartz Scheduler Instance, if a different  
  3. # properties file is not explicitly specified.  
  4. #  
  5.   
  6. #==============================================================      
  7. #Configure Main Scheduler Properties      
  8. #==============================================================       
  9. org.quartz.scheduler.instanceName = quartzScheduler    
  10. org.quartz.scheduler.instanceId = AUTO    
  11.     
  12. #==============================================================      
  13. #Configure JobStore      
  14. #==============================================================     
  15. org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX    
  16. org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.StdJDBCDelegate    
  17. org.quartz.jobStore.tablePrefix = QRTZ_    
  18. org.quartz.jobStore.isClustered = true    
  19. org.quartz.jobStore.clusterCheckinInterval = 600000      
  20. org.quartz.jobStore.dataSource = myDS    
  21.      
  22. #==============================================================      
  23. #Configure DataSource      
  24. #==============================================================     
  25. org.quartz.dataSource.myDS.driver = com.mysql.jdbc.Driver    
  26. org.quartz.dataSource.myDS.URL = jdbc:mysql://localhost:3306/quartzdb?useUnicode=true&amp;characterEncoding=UTF-8    
  27. org.quartz.dataSource.myDS.user = root    
  28. org.quartz.dataSource.myDS.password = www.ydyrx.com    
  29. org.quartz.dataSource.myDS.maxConnections = 30    
  30.     
  31. #==============================================================      
  32. #Configure ThreadPool      
  33. #==============================================================     
  34. org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool    
  35. org.quartz.threadPool.threadCount = 10    
  36. org.quartz.threadPool.threadPriority = 5    
  37. org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread = true  

 这个文件你拿过来改下连接就行

然后是创建数据库

数据库名称是  quartzdb

Sql代码 
  1. /*  
  2.  Navicat MySQL Data Transfer  
  3.   
  4.  Source Server         : localhost  
  5.  Source Server Version : 50611  
  6.  Source Host           : localhost  
  7.  Source Database       : quartzdb  
  8.   
  9.  Target Server Version : 50611  
  10.  File Encoding         : utf-8  
  11.   From:http:www.ydyrx.com  
  12.  Date: 12/09/2013 11:41:36 AM  
  13. */  
  14.   
  15. SET NAMES utf8;  
  16. SET FOREIGN_KEY_CHECKS = 0;  
  17.   
  18. -- ----------------------------  
  19. --  Table structure for `QRTZ_BLOB_TRIGGERS`  
  20. -- ----------------------------  
  21. DROP TABLE IF EXISTS `QRTZ_BLOB_TRIGGERS`;  
  22. CREATE TABLE `QRTZ_BLOB_TRIGGERS` (  
  23.   `SCHED_NAME` varchar(120) COLLATE utf8_bin NOT NULL,  
  24.   `TRIGGER_NAME` varchar(200) COLLATE utf8_bin NOT NULL,  
  25.   `TRIGGER_GROUP` varchar(200) COLLATE utf8_bin NOT NULL,  
  26.   `BLOB_DATA` blob,  
  27.   PRIMARY KEY (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`),  
  28.   KEY `SCHED_NAME` (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`),  
  29.   CONSTRAINT `qrtz_blob_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) REFERENCES `QRTZ_TRIGGERS` (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`)  
  30. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;  
  31.   
  32. -- ----------------------------  
  33. --  Table structure for `QRTZ_CALENDARS`  
  34. -- ----------------------------  
  35. DROP TABLE IF EXISTS `QRTZ_CALENDARS`;  
  36. CREATE TABLE `QRTZ_CALENDARS` (  
  37.   `SCHED_NAME` varchar(120) COLLATE utf8_bin NOT NULL,  
  38.   `CALENDAR_NAME` varchar(200) COLLATE utf8_bin NOT NULL,  
  39.   `CALENDAR` blob NOT NULL,  
  40.   PRIMARY KEY (`SCHED_NAME`,`CALENDAR_NAME`)  
  41. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;  
  42.   
  43. -- ----------------------------  
  44. --  Table structure for `QRTZ_CRON_TRIGGERS`  
  45. -- ----------------------------  
  46. DROP TABLE IF EXISTS `QRTZ_CRON_TRIGGERS`;  
  47. CREATE TABLE `QRTZ_CRON_TRIGGERS` (  
  48.   `SCHED_NAME` varchar(120) COLLATE utf8_bin NOT NULL,  
  49.   `TRIGGER_NAME` varchar(200) COLLATE utf8_bin NOT NULL,  
  50.   `TRIGGER_GROUP` varchar(200) COLLATE utf8_bin NOT NULL,  
  51.   `CRON_EXPRESSION` varchar(120) COLLATE utf8_bin NOT NULL,  
  52.   `TIME_ZONE_ID` varchar(80) COLLATE utf8_bin DEFAULT NULL,  
  53.   PRIMARY KEY (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`),  
  54.   CONSTRAINT `qrtz_cron_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) REFERENCES `QRTZ_TRIGGERS` (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`)  
  55. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;  
  56.   
  57. -- ----------------------------  
  58. --  Table structure for `QRTZ_FIRED_TRIGGERS`  
  59. -- ----------------------------  
  60. DROP TABLE IF EXISTS `QRTZ_FIRED_TRIGGERS`;  
  61. CREATE TABLE `QRTZ_FIRED_TRIGGERS` (  
  62.   `SCHED_NAME` varchar(120) COLLATE utf8_bin NOT NULL,  
  63.   `ENTRY_ID` varchar(95) COLLATE utf8_bin NOT NULL,  
  64.   `TRIGGER_NAME` varchar(200) COLLATE utf8_bin NOT NULL,  
  65.   `TRIGGER_GROUP` varchar(200) COLLATE utf8_bin NOT NULL,  
  66.   `INSTANCE_NAME` varchar(200) COLLATE utf8_bin NOT NULL,  
  67.   `FIRED_TIME` bigint(13) NOT NULL,  
  68.   `PRIORITY` int(11) NOT NULL,  
  69.   `STATE` varchar(16) COLLATE utf8_bin NOT NULL,  
  70.   `JOB_NAME` varchar(200) COLLATE utf8_bin DEFAULT NULL,  
  71.   `JOB_GROUP` varchar(200) COLLATE utf8_bin DEFAULT NULL,  
  72.   `IS_NONCONCURRENT` varchar(1) COLLATE utf8_bin DEFAULT NULL,  
  73.   `REQUESTS_RECOVERY` varchar(1) COLLATE utf8_bin DEFAULT NULL,  
  74.   PRIMARY KEY (`SCHED_NAME`,`ENTRY_ID`),  
  75.   KEY `IDX_QRTZ_FT_TRIG_INST_NAME` (`SCHED_NAME`,`INSTANCE_NAME`),  
  76.   KEY `IDX_QRTZ_FT_INST_JOB_REQ_RCVRY` (`SCHED_NAME`,`INSTANCE_NAME`,`REQUESTS_RECOVERY`),  
  77.   KEY `IDX_QRTZ_FT_J_G` (`SCHED_NAME`,`JOB_NAME`,`JOB_GROUP`),  
  78.   KEY `IDX_QRTZ_FT_JG` (`SCHED_NAME`,`JOB_GROUP`),  
  79.   KEY `IDX_QRTZ_FT_T_G` (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`),  
  80.   KEY `IDX_QRTZ_FT_TG` (`SCHED_NAME`,`TRIGGER_GROUP`)  
  81. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;  
  82.   
  83. -- ----------------------------  
  84. --  Table structure for `QRTZ_JOB_DETAILS`  
  85. -- ----------------------------  
  86. DROP TABLE IF EXISTS `QRTZ_JOB_DETAILS`;  
  87. CREATE TABLE `QRTZ_JOB_DETAILS` (  
  88.   `SCHED_NAME` varchar(120) COLLATE utf8_bin NOT NULL,  
  89.   `JOB_NAME` varchar(200) COLLATE utf8_bin NOT NULL,  
  90.   `JOB_GROUP` varchar(200) COLLATE utf8_bin NOT NULL,  
  91.   `DESCRIPTION` varchar(250) COLLATE utf8_bin DEFAULT NULL,  
  92.   `JOB_CLASS_NAME` varchar(250) COLLATE utf8_bin NOT NULL,  
  93.   `IS_DURABLE` varchar(1) COLLATE utf8_bin NOT NULL,  
  94.   `IS_NONCONCURRENT` varchar(1) COLLATE utf8_bin NOT NULL,  
  95.   `IS_UPDATE_DATA` varchar(1) COLLATE utf8_bin NOT NULL,  
  96.   `REQUESTS_RECOVERY` varchar(1) COLLATE utf8_bin NOT NULL,  
  97.   `JOB_DATA` blob,  
  98.   PRIMARY KEY (`SCHED_NAME`,`JOB_NAME`,`JOB_GROUP`),  
  99.   KEY `IDX_QRTZ_J_REQ_RECOVERY` (`SCHED_NAME`,`REQUESTS_RECOVERY`),  
  100.   KEY `IDX_QRTZ_J_GRP` (`SCHED_NAME`,`JOB_GROUP`)  
  101. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;  
  102.   
  103. -- ----------------------------  
  104. --  Table structure for `QRTZ_LOCKS`  
  105. -- ----------------------------  
  106. DROP TABLE IF EXISTS `QRTZ_LOCKS`;  
  107. CREATE TABLE `QRTZ_LOCKS` (  
  108.   `SCHED_NAME` varchar(120) COLLATE utf8_bin NOT NULL,  
  109.   `LOCK_NAME` varchar(40) COLLATE utf8_bin NOT NULL,  
  110.   PRIMARY KEY (`SCHED_NAME`,`LOCK_NAME`)  
  111. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;  
  112.   
  113. -- ----------------------------  
  114. --  Table structure for `QRTZ_PAUSED_TRIGGER_GRPS`  
  115. -- ----------------------------  
  116. DROP TABLE IF EXISTS `QRTZ_PAUSED_TRIGGER_GRPS`;  
  117. CREATE TABLE `QRTZ_PAUSED_TRIGGER_GRPS` (  
  118.   `SCHED_NAME` varchar(120) COLLATE utf8_bin NOT NULL,  
  119.   `TRIGGER_GROUP` varchar(200) COLLATE utf8_bin NOT NULL,  
  120.   PRIMARY KEY (`SCHED_NAME`,`TRIGGER_GROUP`)  
  121. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;  
  122.   
  123. -- ----------------------------  
  124. --  Table structure for `QRTZ_SCHEDULER_STATE`  
  125. -- ----------------------------  
  126. DROP TABLE IF EXISTS `QRTZ_SCHEDULER_STATE`;  
  127. CREATE TABLE `QRTZ_SCHEDULER_STATE` (  
  128.   `SCHED_NAME` varchar(120) COLLATE utf8_bin NOT NULL,  
  129.   `INSTANCE_NAME` varchar(200) COLLATE utf8_bin NOT NULL,  
  130.   `LAST_CHECKIN_TIME` bigint(13) NOT NULL,  
  131.   `CHECKIN_INTERVAL` bigint(13) NOT NULL,  
  132.   PRIMARY KEY (`SCHED_NAME`,`INSTANCE_NAME`)  
  133. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;  
  134.   
  135. -- ----------------------------  
  136. --  Table structure for `QRTZ_SIMPLE_TRIGGERS`  
  137. -- ----------------------------  
  138. DROP TABLE IF EXISTS `QRTZ_SIMPLE_TRIGGERS`;  
  139. CREATE TABLE `QRTZ_SIMPLE_TRIGGERS` (  
  140.   `SCHED_NAME` varchar(120) COLLATE utf8_bin NOT NULL,  
  141.   `TRIGGER_NAME` varchar(200) COLLATE utf8_bin NOT NULL,  
  142.   `TRIGGER_GROUP` varchar(200) COLLATE utf8_bin NOT NULL,  
  143.   `REPEAT_COUNT` bigint(7) NOT NULL,  
  144.   `REPEAT_INTERVAL` bigint(12) NOT NULL,  
  145.   `TIMES_TRIGGERED` bigint(10) NOT NULL,  
  146.   PRIMARY KEY (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`),  
  147.   CONSTRAINT `qrtz_simple_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) REFERENCES `QRTZ_TRIGGERS` (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`)  
  148. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;  
  149.   
  150. -- ----------------------------  
  151. --  Table structure for `QRTZ_SIMPROP_TRIGGERS`  
  152. -- ----------------------------  
  153. DROP TABLE IF EXISTS `QRTZ_SIMPROP_TRIGGERS`;  
  154. CREATE TABLE `QRTZ_SIMPROP_TRIGGERS` (  
  155.   `SCHED_NAME` varchar(120) COLLATE utf8_bin NOT NULL,  
  156.   `TRIGGER_NAME` varchar(200) COLLATE utf8_bin NOT NULL,  
  157.   `TRIGGER_GROUP` varchar(200) COLLATE utf8_bin NOT NULL,  
  158.   `STR_PROP_1` varchar(512) COLLATE utf8_bin DEFAULT NULL,  
  159.   `STR_PROP_2` varchar(512) COLLATE utf8_bin DEFAULT NULL,  
  160.   `STR_PROP_3` varchar(512) COLLATE utf8_bin DEFAULT NULL,  
  161.   `INT_PROP_1` int(11) DEFAULT NULL,  
  162.   `INT_PROP_2` int(11) DEFAULT NULL,  
  163.   `LONG_PROP_1` bigint(20) DEFAULT NULL,  
  164.   `LONG_PROP_2` bigint(20) DEFAULT NULL,  
  165.   `DEC_PROP_1` decimal(13,4) DEFAULT NULL,  
  166.   `DEC_PROP_2` decimal(13,4) DEFAULT NULL,  
  167.   `BOOL_PROP_1` varchar(1) COLLATE utf8_bin DEFAULT NULL,  
  168.   `BOOL_PROP_2` varchar(1) COLLATE utf8_bin DEFAULT NULL,  
  169.   PRIMARY KEY (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`),  
  170.   CONSTRAINT `qrtz_simprop_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`) REFERENCES `QRTZ_TRIGGERS` (`SCHED_NAME`, `TRIGGER_NAME`, `TRIGGER_GROUP`)  
  171. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;  
  172.   
  173. -- ----------------------------  
  174. --  Table structure for `QRTZ_TRIGGERS`  
  175. -- ----------------------------  
  176. DROP TABLE IF EXISTS `QRTZ_TRIGGERS`;  
  177. CREATE TABLE `QRTZ_TRIGGERS` (  
  178.   `SCHED_NAME` varchar(120) COLLATE utf8_bin NOT NULL,  
  179.   `TRIGGER_NAME` varchar(200) COLLATE utf8_bin NOT NULL,  
  180.   `TRIGGER_GROUP` varchar(200) COLLATE utf8_bin NOT NULL,  
  181.   `JOB_NAME` varchar(200) COLLATE utf8_bin NOT NULL,  
  182.   `JOB_GROUP` varchar(200) COLLATE utf8_bin NOT NULL,  
  183.   `DESCRIPTION` varchar(250) COLLATE utf8_bin DEFAULT NULL,  
  184.   `NEXT_FIRE_TIME` bigint(13) DEFAULT NULL,  
  185.   `PREV_FIRE_TIME` bigint(13) DEFAULT NULL,  
  186.   `PRIORITY` int(11) DEFAULT NULL,  
  187.   `TRIGGER_STATE` varchar(16) COLLATE utf8_bin NOT NULL,  
  188.   `TRIGGER_TYPE` varchar(8) COLLATE utf8_bin NOT NULL,  
  189.   `START_TIME` bigint(13) NOT NULL,  
  190.   `END_TIME` bigint(13) DEFAULT NULL,  
  191.   `CALENDAR_NAME` varchar(200) COLLATE utf8_bin DEFAULT NULL,  
  192.   `MISFIRE_INSTR` smallint(2) DEFAULT NULL,  
  193.   `JOB_DATA` blob,  
  194.   PRIMARY KEY (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`),  
  195.   KEY `IDX_QRTZ_T_J` (`SCHED_NAME`,`JOB_NAME`,`JOB_GROUP`),  
  196.   KEY `IDX_QRTZ_T_JG` (`SCHED_NAME`,`JOB_GROUP`),  
  197.   KEY `IDX_QRTZ_T_C` (`SCHED_NAME`,`CALENDAR_NAME`),  
  198.   KEY `IDX_QRTZ_T_G` (`SCHED_NAME`,`TRIGGER_GROUP`),  
  199.   KEY `IDX_QRTZ_T_STATE` (`SCHED_NAME`,`TRIGGER_STATE`),  
  200.   KEY `IDX_QRTZ_T_N_STATE` (`SCHED_NAME`,`TRIGGER_NAME`,`TRIGGER_GROUP`,`TRIGGER_STATE`),  
  201.   KEY `IDX_QRTZ_T_N_G_STATE` (`SCHED_NAME`,`TRIGGER_GROUP`,`TRIGGER_STATE`),  
  202.   KEY `IDX_QRTZ_T_NEXT_FIRE_TIME` (`SCHED_NAME`,`NEXT_FIRE_TIME`),  
  203.   KEY `IDX_QRTZ_T_NFT_ST` (`SCHED_NAME`,`TRIGGER_STATE`,`NEXT_FIRE_TIME`),  
  204.   KEY `IDX_QRTZ_T_NFT_MISFIRE` (`SCHED_NAME`,`MISFIRE_INSTR`,`NEXT_FIRE_TIME`),  
  205.   KEY `IDX_QRTZ_T_NFT_ST_MISFIRE` (`SCHED_NAME`,`MISFIRE_INSTR`,`NEXT_FIRE_TIME`,`TRIGGER_STATE`),  
  206.   KEY `IDX_QRTZ_T_NFT_ST_MISFIRE_GRP` (`SCHED_NAME`,`MISFIRE_INSTR`,`NEXT_FIRE_TIME`,`TRIGGER_GROUP`,`TRIGGER_STATE`),  
  207.   CONSTRAINT `qrtz_triggers_ibfk_1` FOREIGN KEY (`SCHED_NAME`, `JOB_NAME`, `JOB_GROUP`) REFERENCES `QRTZ_JOB_DETAILS` (`SCHED_NAME`, `JOB_NAME`, `JOB_GROUP`)  
  208. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;  
  209.   
  210. SET FOREIGN_KEY_CHECKS = 1;  

 

接下来就是写方法了,只需要继承 QuartzJobBean

并重写executeInternal方法就行,要自动执行的命令放进这个方法里就可以

Java代码 
  1. public class Try extends QuartzJobBean {  
  2.   
  3.     @Override  
  4.     protected void executeInternal(JobExecutionContext context)  
  5.             throws JobExecutionException {  
  6.         // TODO Auto-generated method stub  
  7.         System.out.println("TRy");  
  8.     }  
  9.   
  10. }  

 接下来就可以运行了

关于时间配置

这些星号由左到右按顺序代表 :     *    *     *     *    *     *   *     
                           格式: [秒] [分] [小时] [日] [月] [周] [年] 





序号 说明 
  是否必填  允许填写的值 允许的通配符 

1  秒  是  0-59    , - * / 
2  分  是  0-59 
   , - * / 
3 小时  是  0-23   , - * / 
4  日  是  1-31   , - * ? / L W 
5  月  是  1-12 or JAN-DEC   , - * / 
6  周  是  1-7 or SUN-SAT   , - * ? / L # 
7  年  否  empty 或 1970-2099  , - * / 


通配符说明: 
* 表示所有值. 例如:在分的字段上设置 "*",表示每一分钟都会触发。 
? 表示不指定值。使用的场景为不需要关心当前设置这个字段的值。例如:要在每月的10号触发一个操作,但不关心是周几,所以需要周位置的那个字段设置为"?" 具体设置为 0 0 0 10 * ? 
- 表示区间。例如 在小时上设置 "10-12",表示 10,11,12点都会触发。 
, 表示指定多个值,例如在周字段上设置 "MON,WED,FRI" 表示周一,周三和周五触发 
/ 用于递增触发。如在秒上面设置"5/15" 表示从5秒开始,每增15秒触发(5,20,35,50)。在月字段上设置'1/3'所示每月1号开始,每隔三天触发一次。 
L 表示最后的意思。在日字段设置上,表示当月的最后一天(依据当前月份,如果是二月还会依据是否是润年[leap]), 在周字段上表示星期六,相当于"7"或"SAT"。如果在"L"前加上数字,则表示该数据的最后一个。例如在周字段上设置"6L"这样的格式,则表示“本月最后一个星期五" 
W 表示离指定日期的最近那个工作日(周一至周五). 例如在日字段上设置"15W",表示离每月15号最近的那个工作日触发。如果15号正好是周六,则找最近的周五(14号)触发, 如果15号是周未,则找最近的下周一(16号)触发.如果15号正好在工作日(周一至周五),则就在该天触发。如果指定格式为 "1W",它则表示每月1号往后最近的工作日触发。如果1号正是周六,则将在3号下周一触发。(注,"W"前只能设置具体的数字,不允许区间"-"). 

小提示 
'L'和 'W'可以一组合使用。如果在日字段上设置"LW",则表示在本月的最后一个工作日触发(一般指发工资 ) 


# 序号(表示每月的第几个周几),例如在周字段上设置"6#3"表示在每月的第三个周六.注意如果指定"#5",正好第五周没有周六,则不会触发该配置(用在母亲节和父亲节再合适不过了) 

小提示 
周字段的设置,若使用英文字母是不区分大小写的 MON 与mon相同. 



      
常用示例: 


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分每分触发 
0 0/5 14 * * ? 每天下午的 2点到2点59分(整点开始,每隔5分触发) 
0 0/5 14,18 * * ? 每天下午的 2点到2点59分(整点开始,每隔5分触发) 
每天下午的 18点到18点59分(整点开始,每隔5分触发) 

0 0-5 14 * * ? 每天下午的 2点到2点05分每分触发 
0 10,44 14 ? 3 WED     3月分每周三下午的 2点10分和2点44分触发 (特殊情况,在一个时间设置里,执行两次或                                                             两次以上的情况) 
0 59 2 ? * FRI    每周5凌晨2点59分触发; 
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 每月的第三周的星期五开始触发 
0 0 12 1/5 * ? 每月的第一个中午开始每隔5天触发一次 
0 11 11 11 11 ? 每年的11月11号 11点11分触发(光棍节) 

 

新手注意

 1,注意如果不报错也不好使请确认是否引入spring-quartz.xml

 2,如果报 与durability相关的错误,请确认你的spring版本,3.1.1有这个参数,3.1.0是没有的,不知道之前的版本有没有。

3,如果你要调用spring用注解自动注入的bean会失败,解决办法如下

 

 

Java代码 
  1. public class SpringBeanJobFactory extends org.springframework.scheduling.quartz.SpringBeanJobFactory implements  
  2.         ApplicationContextAware {  
  3.     private ApplicationContext applicationContext;  
  4.   
  5.     @Override  
  6.     public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {  
  7.         this.applicationContext = applicationContext;  
  8.     }  
  9.   
  10.     /** 
  11.      * 这里我们覆盖了super的createJobInstance方法,对其创建出来的类再进行autowire。 
  12.      */  
  13.     @Override  
  14.     protected Object createJobInstance(TriggerFiredBundle bundle) throws Exception {  
  15.         Object jobInstance = super.createJobInstance(bundle);  
  16.         applicationContext.getAutowireCapableBeanFactory().autowireBean(jobInstance);  
  17.         return jobInstance;  
  18.     }  
  19.   
  20. }  

 然后在web.xml中配置

 

    <listener>

 

    <listener-class>com.asp.rc.spring.ShutdownQuartzListener</listener-class>

 

  </listener>

 

在org.springframework.scheduling.quartz.SchedulerFactoryBean配置总填上这句

<property name="jobFactory">

            <bean class="com.asp.rc.spring.SpringBeanJobFactory" />

        </property> 

如果你发现重启就不再运行了就把,qrtz_triggers表的TRIGGER_STATE中改成WAITING

根本的解决办法是加监听器

 

Java代码 
  1. public class ShutdownQuartzListener implements ServletContextListener {  
  2.   
  3.         /* 
  4.          * 获取相关bean进行shutdown 
  5.          *  
  6.          * @seejavax.servlet.ServletContextListener#contextDestroyed(javax.servlet. 
  7.          * ServletContextEvent) 
  8.          */  
  9.         @Override  
  10.         public void contextDestroyed(ServletContextEvent arg0) {  
  11.             WebApplicationContext webApplicationContext = (WebApplicationContext) arg0  
  12.                     .getServletContext()  
  13.                     .getAttribute(  
  14.                             WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE);  
  15.             org.quartz.impl.StdScheduler startQuertz = (org.quartz.impl.StdScheduler) webApplicationContext  
  16.                     .getBean("schedulerFactoryBean");  
  17.             if(startQuertz != null) {  
  18.                 startQuertz.shutdown();  
  19.             }  
  20.             try {  
  21.                 Thread.sleep(1000);  
  22.             } catch (InterruptedException e) {  
  23.                 e.printStackTrace();  
  24.             }  
  25.         }  
  26.   
  27.         /* 
  28.          * (non-Javadoc) 
  29.          *  
  30.          * @see 
  31.          * javax.servlet.ServletContextListener#contextInitialized(javax.servlet 
  32.          * .ServletContextEvent) 
  33.          */  
  34.         @Override  
  35.         public void contextInitialized(ServletContextEvent arg0) {  
  36.               
  37.         }  
  38.   
  39.   
  40. }  

 

至此就完美运行了,本文源自www.ydyrx.com

 

<a href="http://www.ydyrx.com" target="_blank" rel="external nofollow" target="_blank" rel="external nofollow" >www.ydyrx.com</a>