欢迎访问昆山宝鼎软件有限公司网站! 设为首页 | 网站地图 | XML | RSS订阅 | 宝鼎邮箱 | 宝鼎售后问题提交 | 后台管理


新闻资讯

MENU

软件开发知识

SpringBoot 按时 图纸加密 任务踩坑记录

点击: 次  来源:劳务派遣管理系统 时间:2017-11-11

原文出处: StormMa

媒介

springboot已经支持了按时任务Schedule模块,一般环境已经完全可以或许满意我们的实际需求。本日就记录一下我利用 schedule 时候踩的坑吧。

想要利用按时,我们首先要开启支持,其实就是在启动类上面加个注解就 Ok。

@SpringBootApplication
@EnableScheduling
public class Application {
    public static void main(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

注: 这个是官方表明

0 0 3 * * ?     天天3点执行
0 5 3 * * ?     天天3点5分执行
0 5 3 ? * *     天天3点5分执行,与上面浸染沟通
0 5/10 3 * * ?  天天3点的 5分,15分,25分,35分,45分,55分这几个时间点执行
0 10 3 ? * 1    每周礼拜天,劳务派遣管理系统,3点10分 执行,注:1暗示礼拜天    
0 10 3 ? * 1#3  每个月的第三个礼拜,礼拜天 执行,#号只能呈此刻礼拜的位置

在此我要说明,劳务派遣管理系统,springBoot 中的 schedule 支持的 cron 表达式和这个不太相符,官方说的礼拜暗示,1是周天,依次类推,可是我在测试进程中,1实际上代表的就是周一,口说无凭
那我就来贴代码和测试功效吧.

@Component
@EnableScheduling
public class Task {
    private static final Logger LOGGER = MyLogger.getLogger(Task.class);
    @Scheduled(cron = "0 46 20 ? * 1")
    public void task() {
        LOGGER.info("传闻本日是周日");
    }

测试功效:

2017-05-08 20:46:00.006  INFO 18838 --- [pool-1-thread-1] com.yiyexy.task.Task                     : 传闻本日是周日

凭据上面的表明来讲,第六域是礼拜,而且值是1那么代表是周日运行,可是我的运行功效表白是周一运行,我在此暗示很无奈。
最后我以为用单词来暗示周几,这样就不会出这种问题了,于是

@Component
@EnableScheduling
public class Task {
    private static final Logger LOGGER = MyLogger.getLogger(Task.class);
    @Scheduled(cron = "0 49 20 ? * MON")
    public void task() {
        LOGGER.info("传闻本日是周日");
    }
}

测试功效:

2017-05-08 20:49:00.005  INFO 18864 --- [pool-1-thread-1] com.yiyexy.task.Task                     : 传闻本日是周日

好了,这个坑就记录到这吧,最后送上一句,时间是检讨真理的独一尺度。