一、SpringBoot中 定时器
1、环境描述:SrpingBoot Version Is 2.x
2、见代码:【@EnableScheduling可直接加在启动类上】
/** * SpringBoot 2.x 定时器测试 * * @author Francis * @date 2018-09-18 21:05 */ @Component @EnableScheduling public class TaskService { /** * 每隔5秒钟执行一次 */ @Scheduled(cron = "*/5 * * * * ?") public void testTask() { Date date = new Date(); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); System.out.println(sdf.format(date) + " : 执行了定时器"); } }
3、cron相关参数:
1)、各字段含义:
字段 允许值 允许的特殊字符 秒(Seconds) 0~59的整数 , - * / 共计4个字符 分(Minutes) 0~59的整数 , - * / 共计4个字符 小时(Hours) 0~23的整数 , - * / 共计4个字符 日期(DayofMonth) 1~31的整数(需要考虑月的天数) , - * / ? L W C 共计8个字符 月份(Month) 1~12的整数 或 JAN-DEC , - * / 共计4个字符 星期(DayofWeek) 1~7的整数或者SUN-SAT( 1= SUN) , - * / ? L C # 共计8个字符 年(可选,留空)(Year) 1970~2099 , - * / 共计4个字符 2)、特殊字符含义:
字符 含义 , 表示列出枚举值。如:在'分'位置上使用 :5,20,表示在5分和20分的时候每分钟触发一次。 - 表示范围。如:在‘分’位置上使用:5-20,表示5分到20分这个区间内,每分钟触发一次。 * 标识匹配该域的任何值。如:在 ‘分’ 位置上使用 *, 代表每分钟都会触发事件 / x/y,表示起始时间x开始触发,然后每隔固定时间y触发一次。如在‘秒’:0/15,表示从0秒开始,每15秒,最后就是0,15,30,45,60触发。另:*/y,等同于0/y ? ‘日期’和‘星期’会相互影响。如:预计在每月的20日13:00:00触发:13 13 15 20 * ?。最后一位只能是‘?’ L 表示最后。如:在星期上使用:1L,表示在最后一个星期日触发。 W 表示有效工作日(周一到周五),只能出现在‘日期’域,系统将在离指定日期的最近的有效工作日触发事件。如:使用:5W,如果5日是星期六,则将在最近的工作日:星期五,即4日触发。如果5日是星期天,则在6日(周一)触发;如果5日在星期一到星期五中的一天,则就在5日触发。另外一点,W的最近寻找不会跨过月份 。 LW 表示某个月的最后一个工作日,即最后一个星期五。 # x#y:确定每个月第y个星期(x-1),只能出现在‘星期’域。如:4#2,表示某月的第2个星期三。
3)、常用例子:
corn常用表达式 含义 0 0 2 1 * ? 每月的1日凌晨2点执行 0 15 10 ? * MON-FRI 周一到周五早上10:15执行 0 15 10 ? 6L 2002-2006 2002 -- 2006年的每个月的最后一个周五上午10:15执行 0 0 10,14,16 * * ? 每天10点、14点、16点执行 0 0/30 9-17 * * ? 每天9:00--17:00,每半个小时执行一次 0 0 12 ? * WED 每周三12:00执行 0 0 12 * * ? 每天12:00执行 0 15 10 ? * * 每天10:15执行 0 15 10 * * ? 每天10:15执行 0 15 10 * * ? * 每天10:15执行 0 15 10 * * ? 2005 2005的每天上午10:15执行 0 * 14 * * ? 每天14:00 -- 14:59 期间,每分钟执行一次 0 0/5 14 * * ? 每天14:00 -- 14:59 期间,每5分钟执行一次 0 0/5 14,18 * * ? 每天14:00 -- 14:59、18:00 -- 18:59,每5分钟执行一次 0 0-5 14 * * ? 每天14:00 -- 14:05 期间,每分钟执行一次 0 10,44 14 ? 3 WED 每年3月的周三14:10 和 14:44执行 0 15 10 ? * MON-FRI 周一至周五的10:15执行 0 15 10 15 * ? 每月15日10:15执行 0 15 10 L * ? 每月最后一日的10:15执行 0 15 10 ? * 6L 每月的最后一个周五10:15执行 0 15 10 ? * 6L 2002-2005 2002 -- 2005年的每月最后一个周五10:15触发 0 15 10 ? * 6#3 每月的第三个周五10:15触发
二、SpringBoot 时间转换注解
注解 说明 @DateTimeFormat(pattern="yyyy-MM-dd HH:mm")
1、将String转换为Date。
2、一般用于前端给后端传值时使用。@JsonFormat(timezone = "GMT+8",pattern = "yyyy-MM-dd HH:mm")
1、将Date转换为String。
2、一般用于后端给前端返回值用。
3、此注解会让时间以0区时间显示,若直接使用会少8小时,故此处有 timezone = "GMT+8