SpringBoot 定时任务
2019-12-14 16:02:17来源:博客园 阅读 ()
SpringBoot 定时任务
1.如何定时任务
1.1 开启定时任务
@EnableScheduling //开启定时任务 @SpringBootApplication public class ManagerApplication { private static Logger logger = LoggerFactory.getLogger(ManagerApplication.class); public static void main(String[] args) { SpringApplication.run(ManagerApplication.class, args); logger.info("------------------------------------------------------------------"); logger.info("application start success..."); logger.info("--" + "----------------------------------------------------------------"); try { System.in.read(); } catch (IOException e) { e.printStackTrace(); } } }
1.2 @Scheduled(预定的)选择要定时执行的任务
@Component public class ScheduledService { @Scheduled(fixedRate = 1000*60*60) public void scheduled1() { } }
== 定时在前一个任务阻塞时 会等待他,这个时候可以通过@Async 用异步来解决 ==
2.@Scheduled 参数详解
2.1 cron
2.1.1 cron表达式语法
通配符说明
, :表示指定多个值, 例如:在分的字段上设置 1,2,3,则1,2,3 分钟都会运行。
*:表示所有值。 例如:在分的字段上设置 *,表示每一分钟都会触发。
? :表示不指定值。只能在日和星期(周)中指定使用
-表示区间。例如:在分钟上设置1-10表示 1到10分钟都会 运行。
/ 用于递增触发。例如:在分上面设置”1/1” 表示从1分钟开始,每增1分钟触发一次(1,2,3,4…)
L: 表示最后(last)的意思(只支持月和星期)。在日字段设置上,表示当月的最后一天, 在星期字段上表示星期六,相当于”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相同。
== 日和星期 只能存在一个 另一个用 ? ==
2.2 zone(地区)
cron表达式会基于该时区解析
2.3 fixedDelay
上一次执行后多少毫秒后执行注意是上一次执行完毕后
@Scheduled(fixedDelay = 2000)
开始,现在时间是 : 11:37:48scheduling-1 2019-12-12 11:37:48.884 INFO 18064 --- [ main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat started on port(s): 8086 (http) with context path '' 2019-12-12 11:37:48.891 INFO 18064 --- [ main] com.wlgj.manager.ManagerApplication : Started ManagerApplication in 7.266 seconds (JVM running for 10.023) 2019-12-12 11:37:48.894 INFO 18064 --- [ main] com.wlgj.manager.ManagerApplication : ------------------------------------------------------------------ 2019-12-12 11:37:48.895 INFO 18064 --- [ main] com.wlgj.manager.ManagerApplication : application start success... 2019-12-12 11:37:48.895 INFO 18064 --- [ main] com.wlgj.manager.ManagerApplication : ------------------------------------------------------------------ 结束,现在时间是 : 11:37:51scheduling-1 开始,现在时间是 : 11:37:53scheduling-1 结束,现在时间是 : 11:37:56scheduling-1 开始,现在时间是 : 11:37:58scheduling-1 结束,现在时间是 : 11:38:01scheduling-1
2.4 fixedRate
上一次执行开始多少毫秒后执行注意是上一次执行开始后
@Scheduled(fixedRate=2000) @Async public void test() { System.out.println("开始,现在时间是 : "+format.format(new Date())+""+Thread.currentThread().getName()); try { Thread.sleep(3000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("结束,现在时间是 : "+format.format(new Date())+""+Thread.currentThread().getName()); }
开始,现在时间是 : 11:43:26ThreadPoolTaskExecutor-1 2019-12-12 11:43:26.379 INFO 17976 --- [ main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat started on port(s): 8086 (http) with context path '' 2019-12-12 11:43:26.385 INFO 17976 --- [ main] com.wlgj.manager.ManagerApplication : Started ManagerApplication in 7.273 seconds (JVM running for 9.84) 2019-12-12 11:43:26.389 INFO 17976 --- [ main] com.wlgj.manager.ManagerApplication : ------------------------------------------------------------------ 2019-12-12 11:43:26.390 INFO 17976 --- [ main] com.wlgj.manager.ManagerApplication : application start success... 2019-12-12 11:43:26.390 INFO 17976 --- [ main] com.wlgj.manager.ManagerApplication : ------------------------------------------------------------------ 开始,现在时间是 : 11:43:28ThreadPoolTaskExecutor-2 结束,现在时间是 : 11:43:29ThreadPoolTaskExecutor-1 开始,现在时间是 : 11:43:30ThreadPoolTaskExecutor-3 结束,现在时间是 : 11:43:31ThreadPoolTaskExecutor-2 开始,现在时间是 : 11:43:32ThreadPoolTaskExecutor-1 结束,现在时间是 : 11:43:33ThreadPoolTaskExecutor-3 开始,现在时间是 : 11:43:34ThreadPoolTaskExecutor-2
————————————————
本人免费整理了Java高级资料,涵盖了Java、Redis、MongoDB、MySQL、Zookeeper、Spring Cloud、Dubbo高并发分布式等教程,一共30G,需要自己领取。
传送门:https://mp.weixin.qq.com/s/osB-BOl6W-ZLTSttTkqMPQ
原文链接:https://www.cnblogs.com/yunxi520/p/12040801.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- springboot2配置JavaMelody与springMVC配置JavaMelody 2020-06-11
- SpringBoot 2.3 整合最新版 ShardingJdbc + Druid + MyBatis 2020-06-11
- 掌握SpringBoot-2.3的容器探针:实战篇 2020-06-11
- nacos~配置中心功能~springboot的支持 2020-06-10
- SpringBoot + Vue + ElementUI 实现后台管理系统模板 -- 后 2020-06-10
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash