SpringBoot 定时任务遇到的坑
前言
springboot已经支持了定时任务Schedule模块,一般情况已经完全能够满足我们的实际需求。今天就记录一下我使用schedule时候踩的坑吧。
想要使用定时,我们首先要开启支持,其实就是在启动类上面加个注解就Ok。
@SpringBootApplication @EnableScheduling publicclassApplication{ publicstaticvoidmain(String[]args){ SpringApplication.run(Application.class,args); } }
这篇博客的主题是记录踩的坑,具体定时任务怎么使用我就不写了,有需要的参考我的博客Spring定时任务。
今天踩的这个坑和cron表达式有关,我们就先来看看cron表达式的解释吧:
Cron表达式是一个字符串,字符串以5或6个空格隔开,分为6或7个域,每一个域代表一个含义
解释
*第一位,表示秒,取值0-59
*第二位,表示分,取值0-59
*第三位,表示小时,取值0-23
*第四位,日期天/日,取值1-31
*第五位,日期月份,取值1-12
*第六位,星期,取值1-7,星期一,星期二...,注:不是第1周,第二周的意思
另外:1表示星期天,2表示星期一。
*第7为,年份,可以留空,取值1970-2099
(*)星号:可以理解为每的意思,每秒,每分,每天,每月,每年...
(?)问号:问号只能出现在日期和星期这两个位置,表示这个位置的值不确定,每天3点执行,所以第六位星期的位置,我们是不需要关注的,就是不确定的值。同时:日期和星期是两个相互排斥的元素,通过问号来表明不指定值。比如,1月10日,比如是星期1,如果在星期的位置是另指定星期二,就前后冲突矛盾了。
(-)减号:表达一个范围,如在小时字段中使用“10-12”,则表示从10到12点,即10,11,12
(,)逗号:表达一个列表值,如在星期字段中使用“1,2,4”,则表示星期一,星期二,星期四
(/)斜杠:如:x/y,x是开始值,y是步长,比如在第一位(秒)0/15就是,从0秒开始,每15秒,最后就是0,15,30,45,60 另:*/y,等同于0/y
注:这个是官方解释
003**? 每天3点执行
053**? 每天3点5分执行
053?** 每天3点5分执行,与上面作用相同
05/103**? 每天3点的5分,15分,25分,35分,45分,55分这几个时间点执行
0103?*1 每周星期天,3点10分执行,注:1表示星期天
0103?*1#3 每个月的第三个星期,星期天执行,#号只能出现在星期的位置
在此我要说明,springBoot中的schedule支持的cron表达式和这个不太相符,官方说的星期表示,1是周天,依次类推,但是我在测试过程中,1实际上代表的就是周一,口说无凭
那我就来贴代码和测试结果吧.
@Component @EnableScheduling publicclassTask{ privatestaticfinalLoggerLOGGER=MyLogger.getLogger(Task.class); @Scheduled(cron="04620?*1") publicvoidtask(){ LOGGER.info("听说今天是周日"); }
测试结果:
2017-05-0820:46:00.006 INFO18838---[pool-1-thread-1]com.yiyexy.task.Task :听说今天是周日
按照上面的解释来讲,第六域是星期,并且值是1那么代表是周日运行,但是我的运行结果表明是周一运行,我在此表示很无奈。
最后我觉得用单词来表示周几,这样就不会出这种问题了,于是
@Component @EnableScheduling publicclassTask{ privatestaticfinalLoggerLOGGER=MyLogger.getLogger(Task.class); @Scheduled(cron="04920?*MON") publicvoidtask(){ LOGGER.info("听说今天是周日"); } }
测试结果:
2017-05-0820:49:00.005 INFO18864---[pool-1-thread-1]com.yiyexy.task.Task :听说今天是周日
好了,这个坑就记录到这吧,最后奉上一句,时间是检验真理的唯一标准。
好了,下面看下SpringBoot定时任务的使用
本文介绍在SpringBoot中如何使用定时任务,使用非常简单,就不做过多说明了。
下面是代码类:
packageorg.springboot.sample.config; importorg.slf4j.Logger; importorg.slf4j.LoggerFactory; importorg.springframework.context.annotation.Configuration; importorg.springframework.scheduling.annotation.EnableScheduling; importorg.springframework.scheduling.annotation.Scheduled; /** *定时任务配置类 * *@author单红宇(365384722) *@mybloghttp://blog.csdn.net/catoop/ *@create2016年3月21日 */ @Configuration @EnableScheduling//启用定时任务 publicclassSchedulingConfig{ privatefinalLoggerlogger=LoggerFactory.getLogger(getClass()); @Scheduled(cron="0/20****?")//每20秒执行一次 publicvoidscheduler(){ logger.info(">>>>>>>>>>>>>scheduled..."); } }
总结
以上所述是小编给大家介绍的SpringBoot定时任务遇到的坑,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!