即日起在codingBlog上分享您的技术经验即可获得积分,积分可兑换现金哦。

SpringMVC定时任务注解实现@Schedule

编程语言 xn_28 17℃ 0评论

链接:http://blog.csdn.net/cheney1993/article/details/70162299


原文引用:


Task类:

ManageSql.Java对应代码:


[java] view
plain
 copy

 在CODE上查看代码片派生到我的代码片

  1. package com.axb.cheney.task;  
  2. import java.sql.ResultSet;  
  3. import java.sql.SQLException;  
  4. import org.springframework.scheduling.annotation.Scheduled;  
  5. import org.springframework.stereotype.Component;  
  6.   
  7. /**   
  8.  * 心跳更新。启动时执行一次,之后每隔2秒执行一次   
  9.  * @Scheduled(fixedRate = 1000*2)  
  10.  */  
  11.   
  12. @Component  
  13. public class ManageSql {  
  14.   
  15.     @Scheduled(cron=“0/30 * * * * ? “//间隔5秒执行      
  16.     public void test(){  
  17.         System.out.println(“定时任务开始啦,哈哈哈”);  
  18.         System.out.println(“<<<---------结束执行HR数据同步任务--------->>>”);  
  19.     }  
  20. }  



配置:

applicationContext.xml 中添加以下对应内容 :


1、xmlns 加下面的内容:

xmlns:task=”http://www.springframework.org/schema/task”




2、然后xsi:schemaLocation加下面的内容:


http://www.springframework.org/schema/taskhttp://www.springframework.org/schema/task/spring-task-4.1.xsd




3、最后是我们的task任务扫描注解





4、配置的扫描位置是


添加后,如下图所示:




扩展:定时时间的设置

  如:“0/5 * * * * ?”

  CronTrigger配置完整格式为: [秒] [分] [小时] [日] [月] [周] [年]

序号 说明 是否必填 允许填写的值 允许的通配符
1 0-59 , – * /
2 0-59 , – * /
3 小时 0-23 , – * /
4 1-31 , – * ? / L W
5 1-12或JAN-DEC , – * /
6 1-7或SUN-SAT , – * ? / L W
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”前只能设置具体的数字,不允许区间”-“).




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

小提示:


‘L’和 ‘W’可以组合使用。如果在日字段上设置”LW”,则表示在本月的最后一个工作日触发;


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

 

参考:

https://wuzhuti.cn/850.html/comment-page-1/

https://wuzhuti.cn/447.html





cron表达式规则:


* 字段 允许值 允许的特殊字符


秒 0-59 , – * /


分 0-59 , – * /


小时 0-23 , – * /


日期 1-31 , – * ? / L W C


月份 1-12 或者 JAN-DEC , – * /


星期 1-7 或者 SUN-SAT , – * ? / L C #


年(可选) 留空, 1970-2099 , – * / 


– 区间 


* 通配符 


? 你不想设置那个字段





1 Seconds (0-59) 


2 Minutes (0-59) 


3 Hours (0-23) 


4 Day of month (1-31) 


5 Month (1-12 or JAN-DEC) 


6 Day of week (1-7 or SUN-SAT) 


7 Year (1970-2099) 


取值:可以是单个值,如6; 


也可以是个范围,如9-12; 


也可以是个列表,如9,11,13 


也可以是任意取值,使用* 





CRON表达式 示例:


“0 0 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:55分结束每5分钟一次触发 


“0 0/5 14,18 * * ?” 每天的下午2点至2:55和6点至6点55分两个时间段内每5分钟一次触发 


“0 0-5 14 * * ?” 每天14:00至14:05每分钟一次触发 


“0 10,44 14 ? 3 WED” 三月的每周三的14:10和14:44触发 


“0 15 10 ? * MON-FRI” 每个周一、周二、周三、周四、周五的10:15触发 


“0 * * * * ?” 每分钟(0点0时0分)触发一次


“0 0 * * * ?” 每小时(0点0时0分)触发一次





fixedDelay = 5000 每秒触发一次 这个周期是以上一个调用任务的完成时间为基准,在上一个任务完成之后,5s后再次执行


fixedRate = 5000 每3秒触发一次 固定速率执行,以上一个任务开始时间为基准,从上一任务开始执行后5s再次调用


initialDelay=3000 启动后延迟3秒后开始首次触发




    还可以通过使用zone属性来指定cron表达式被调用的时区。

 

注意:

  1、spring的注解@Scheduled  需要写在实现方法上;

  2、定时器的任务方法不能有返回值(如果有返回值,spring初始化的时候会告诉你有个错误、需要设定一个proxytargetclass的某个值为true),不能指向任何的参数;

  3、如果该方法需要与应用程序上下文的其他对象进行交互,通常是通过依赖注入来实现;

  4、实现类上要有组件的注解@Component。





转载请注明:CodingBlog » SpringMVC定时任务注解实现@Schedule

喜欢 (0)or分享 (0)
发表我的评论
取消评论

*

表情