在春天+ SpringMVC环境中,一般来说,要实现定时任务,我们有两中方案,一种是使用弹簧自带的定时任务处理器@Scheduled注解,另一种就是使用第三方框架石英、弹簧引导源自春天+ SpringMVC,因此天然具备这两个弹簧中的定时任务实现策略,当然也支持石英,本文我们就来看下弹簧引导中两种定时任务的实现方式。
使用@Scheduled非常容易,直接创建一个弹簧启动项目,并且添加web依赖spring-boot-starter-web,项目创建成功后,添加@EnableScheduling注解,开启定时任务:
@SpringBootApplication @EnableScheduling 公开课ScheduledApplication { 公共静态void main (String [] args) { SpringApplication.run (ScheduledApplication.class, args); } }
接下来配置定时任务:
@Scheduled (fixedRate=2000) 公共空间fixedRate () { System.out.println (“fixedRate>在祝辞“+新日期()); } @Scheduled (fixedDelay=2000) 公共空间fixedDelay () { System.out.println (“fixedDelay>在祝辞“+新日期()); } @Scheduled (initialDelay=2000, fixedDelay=2000) 公共空间initialDelay () { System.out.println (“initialDelay>在祝辞“+新日期()); }
-
<李>首先使用@Scheduled注解开启一个定时任务。李>
<李> fixedRate表示任务执行之间的时间间隔,具体是指两次任务的开始时间间隔,即第二次任务开始时,第一次任务可能还没结束。李>
<李> fixedDelay表示任务执行之间的时间间隔,具体是指本次任务结束到下次任务开始之间的时间间隔。李>
<李> initialDelay表示首次任务启动的延迟时间。李>
<李>所有时间的单位都是毫秒。李>
上面这是一个基本用法,除了这几个基本属性之外,@Scheduled注解也支持cron表达式,使用cron表达式,可以非常丰富的描述定时任务的时间.cron表达式格式如下:
[秒][分][小时][日](周)(月)(年)
具体取值如下:
序号 说明 是否必填 允许填写的值 允许的通配符 1 秒 是 0-59 - */2 分 是 0-59 - */3. 时 是 0-23 - */4 日 是 日至31日 - * & # 63;W/L 5 月 是 1 - 12或JAN-DEC - */6 周 是 1 - 7或SUN-SAT - * & # 63;/L # 7 年 否 1970 - 2099 - */
这一块需要大家注意的是,月份中的日期和星期可能会起冲突,因此在配置时这两个得有一个是& # 63;
通配符含义:
-
<李> & # 63;表示不指定值,即不关心某个字段的取值时使用。需要注意的是,月份中的日期和星期可能会起冲突,因此在配置时这两个得有一个是& # 63;李>
<李> *表示所有值,例如:在秒的字段上设置*,表示每一秒都会触发李>
<李>,用来分开多个值,例如在周字段上设置“MON, WED, FRI”表示周一、周三和周五触发李>
<李>——表示区间,例如在秒上设置“10 - 12”,表示10,11,12秒都会触发李>
<李>/用于递增触发,如在秒上面设置“5/15”表示从5秒开始,每增15秒触发(35 5,20日,50)李>
<李> #序号(表示每月的第几个周几),例如在周字段上设置“6 # 3”表示在每月的第三个周六,(用在母亲节和父亲节再合适不过了)李>
<李>周字段的设置,若使用英文字母是不区分大小写的,即我与我相同李>
<李> L表示最后的意思。在日字段设置上,表示当月的最后一天(依据当前月份,如果是二月还会自动判断是否是润年),在周字段上表示星期六,相当于“7”或“坐”(注意周日算是第一天)。如果在“L”前加上数字,则表示该数据的最后一个例。如在周字段上设置“6 L”这样的格式,则表示“本月最后一个星期五”李>
<李> W表示离指定日期的最近工作日(周一至周五),例如在日字段上设置“15 W”,表示离每月15号最近的那个工作日触发。如果15号正好是周六,则找最近的周五(14号)触发,如果15号是周未,则找最近的下周一(16号)触发,如果15号正好在工作日(周一至周五),则就在该天触发。如果指定格式为“1 W”,它则表示每月1号往后最近的工作日触发。如果1号正是周六,则将在3号下周一触发。(注,“W”前只能设置具体的数字,不允许区间“-”)