spring timetask 定时任务调度

时间:2021-03-06 07:48:50
 作者:Garry1115

定时任务调度即在设置的特定时间执行特定的任务,不需要人工干预。

spring timertask

spring 自身所带定时任务类,不需要引入第三方jar包,使用方式如下: EmailReportTask.java
  1. package com.zwx.core;  
  2.   
  3. import java.util.TimerTask;  
  4.   
  5. public class EmailReportTask extends TimerTask{     
  6.     @Override     
  7.     public void run() {     
  8.         System.out.println(" EmailReportTask Run... ");  
  9.     }       
  10. }   
 applicationContext-springtask.xml
  1. <pre name="code" class="java"><!-- Bean -->  
  2.     <bean id="emailReportTask" class="com.zwx.core.EmailReportTask" />  
  3.   
  4.     <!-- ScheduledTimerTask设置定时器属性 : period=定时器周期;delay=延迟多久启动 86400000代表24个小时;timerTask=执行定时任务的类对象 -->  
  5.     <bean id="emailReportScheduleReportTask" class="org.springframework.scheduling.timer.ScheduledTimerTask">  
  6.         <property name="timerTask" ref="emailReportTask" />  
  7.         <property name="period" value="2000" />  
  8.         <property name="delay" value="1000" />  
  9.     </bean>  
  10. <pre name="code" class="java">  
  11. <!-- Spring的TimerFactoryBean负责启动定时任务; scheduledTimerTasks = 需要启动的定时器任务的列表 --><bean class="org.springframework.scheduling.timer.TimerFactoryBean"><property name="scheduledTimerTasks"><list><ref bean="emailReportScheduleReportTask" /></list></property></bean>   

spring quartz

使用第三方定时器实现定时任务,优点:能够对执行时间点的精确配置 自定义任务类:QuartzJob.java
  1. package com.writchie.quartz;   
  2. public class QuartzJob   
  3. {   
  4.      public void work()   
  5.      {   
  6.              System.out.println("zwx提示您:Spring Quartz的任务调度1被调用!");   
  7.              //定时调用的业务逻辑   
  8.      }   
  9. }   
 配置:applicationContext-quartz.xml
  1. <!-- quartz -->  
  2.      <!-- 要调用的工作类 -->   
  3.          <bean id="quartzJob" class="com.writchie.quartz.QuartzJob"></bean>   
  4.          <!-- 可继续加新的任务   -->   
  5.          <!-- 要调用的工作类结束 -->   
  6.   
  7.          <!-- 定义调用对象和调用对象的方法 -->   
  8.          <bean id="jobtask" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">   
  9.              <!-- 调用的类 -->   
  10.              <property name="targetObject">   
  11.                  <ref bean="quartzJob"/>   
  12.              </property>   
  13.              <!-- 调用类中的方法 -->   
  14.              <property name="targetMethod">   
  15.                  <value>work</value>   
  16.              </property>   
  17.          </bean>   
  18.   
  19.          <!-- 可继续加新的   -->   
  20.        <!-- 定义调用对象和调用对象的方法结束 -->   
  21.   
  22.          <!-- 定义触发时间 -->   
  23.          <bean id="doTime" class="org.springframework.scheduling.quartz.CronTriggerBean">   
  24.              <property name="jobDetail">   
  25.                  <ref bean="jobtask"/>   
  26.              </property>   
  27.              <!-- cron表达式 此处定义为一直触发执行任务 -->   
  28.              <property name="cronExpression">   
  29.                  <value>10,15,20,25,30,35,40,45,50,55 * * * * ?</value>   
  30.              </property>   
  31.          </bean>   
  32.            
  33.          <!-- 可继续加新的   -->   
  34.          <!-- 定义触发时间结束 -->   
  35.   
  36.          <!-- 总管理类 如果将lazy-init='false'那么容器启动就会执行调度程序   -->   
  37.          <bean id="startQuertz" lazy-init="false" autowire="no" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">   
  38.              <property name="triggers">   
  39.                  <list>   
  40.                      <ref bean="doTime"/>   
  41.                    <!-- 可继续加新的   -->   
  42.   
  43.                  </list>   
  44.              </property>   
  45.          </bean>   
  46.        <!-- 总管理类结束   -->   
  47. </beans>  
 所需第三方jar包:quartz-all-1.8.3.jar
 

Spring--quartz中cronExpression配置说明 

  1. 字段      允许值         允许的特殊字符  
  2. 秒       0-59        , - * /  
  3. 分       0-59        , - * /  
  4. 小时      0-23        , - * /  
  5. 日期      1-31        , - * ? / L W C  
  6. 月份      1-12 或者 JAN-DEC         , - * /  
  7. 星期      1-7 或者 SUN-SAT      , - * ? / L C #  
  8. 年(可选)       留空, 1970-2099       , - * /  
  1.    
  2. 字段 允许值 允许的特殊字符  
  3. 秒 0-59 , - * /  
  4. 分 0-59 , - * /  
  5. 小时 0-23 , - * /  
  6. 日期 1-31 , - * ? / L W C  
  7. 月份 1-12 或者 JAN-DEC , - * /  
  8. 星期 1-7 或者 SUN-SAT , - * ? / L C #  
  9. 年(可选) 留空, 1970-2099 , - * /  
  10. 表达式意义  
  11. "0 0 12 * * ?" 每天中午12点触发  
  12. "0 15 10 ? * *" 每天上午10:15触发  
  13. "0 15 10 * * ?" 每天上午10:15触发  
  14. "0 15 10 * * ? *" 每天上午10:15触发  
  15. "0 15 10 * * ? 2005" 2005年的每天上午10:15触发  
  16. "0 * 14 * * ?" 在每天下午2点到下午2:59期间的每1分钟触发  
  17. "0 0/5 14 * * ?" 在每天下午2点到下午2:55期间的每5分钟触发  
  18. "0 0/5 14,18 * * ?" 在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发  
  19. "0 0-5 14 * * ?" 在每天下午2点到下午2:05期间的每1分钟触发  
  20. "0 10,44 14 ? 3 WED" 每年三月的星期三的下午2:10和2:44触发  
  21. "0 15 10 ? * MON-FRI" 周一至周五的上午10:15触发  
  22. "0 15 10 15 * ?" 每月15日上午10:15触发  
  23. "0 15 10 L * ?" 每月最后一日的上午10:15触发  
  24. "0 15 10 ? * 6L" 每月的最后一个星期五上午10:15触发  
  25. "0 15 10 ? * 6L 2002-2005" 2002年至2005年的每月的最后一个星期五上午10:15触发  
  26. "0 15 10 ? * 6#3" 每月的第三个星期五上午10:15触发  
  27. 每天早上6点  
  28. 0 6 * * *  
  29. 每两个小时  
  30. 0 */2 * * *  
  31. 晚上11点到早上8点之间每两个小时,早上八点  
  32. 0 23-7/2,8 * * *  
  33. 每个月的4号和每个礼拜的礼拜一到礼拜三的早上11点  
  34. 0 11 4 * 1-3  
  35. 1月1日早上4点  
  36. 0 4 1 1 *