日常中,如果定时任务比较多,可以采用xxl-job这样第三方工具,当然,如果只有一两个,可以使用spring的schedule,方便好用,接下去就让我们去了解下
一、使用;
二、关于注解中一些属性的使用;
实现本质是基于 java 中的 ScheduledExecutorService 类的 schedule 方法。
OK,接下去就进入主题;
一、使用
1、在springboot工程的启动类上添加注解@EnableScheduling
@SpringBootApplication @EnableScheduling //这个 public class DemoApplication {public static void main(String[] args) {SpringApplication.run(DemoApplication.class, args);// 第一次拉取代码 }}
2、建立一个设置定时任务的类,在类上记得添加注解@Component,注入到spring容器中,让其管理,代码如下
@Component public class ScheduledDemo {@Scheduled(cron = "10,30,50 * * * * *")public void test1(){LocalDateTime now = LocalDateTime.now();DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");System.out.println("定时任务执行" + ":" + formatter.format(now));}}
3、在执行的方法上添加@Scheduled注解,基本就完成了整合使用。
从控制台输出就可以看到执行效果
二、@Scheduled注解
该注解有以下属性:
1、corn:corn表达式
从左到右用空格隔开分别是:【秒 分 时 日 月 周 年(可省略)】
第一个位置:Seconds 秒:区间 0-59 秒,代表一分钟内的秒数。
第二个位置:Minutes 分:区间 0-59 分,代表一小时内的分钟数。
第三个位置:Hours 时:区间 0-23 时,代表一天中的小时数。
第四个位置:Day of month 日:区间 1-31 (?根据每月有多少天来),代表一月中的多少号。
第五个位置:Month 月:区间 1-12 ,代表一年中的月份。
第六个位置:Day of week 周:区间 1-7或者英文星期的缩写,代表星期几。
(注意:1 对应周日 SUN , 7 对应周六 SAT ,如此循环)
第七个位置:Year 年:区间1970-2099,代表具体年份,但是一般不用,可以直接不写。
常用示例:
0/5 * * * * ? 每隔5秒执行一次
0 */1 * * * ? 每隔1分钟执行一次
0 0 23 * * ? 每天23点执行一次
0 0 1 * * ? 每天凌晨1点执行一次
0 0 1 1 * ? 每月1号凌晨1点执行一次
0 0 23 L * ? 每月最后一天23点执行一次
0 0 1 ? * L 每周星期天凌晨1点实行一次
0 26,29,33 * * * ? 在26分、29分、33分执行一次
0 0 0,13,18,21 * * ? 每天的0点、13点、18点、21点都执行一次
0 0 10,14,16 * * ? 每天上午10点,下午2点,4点
0 0/30 9-17 * * ? 朝九晚五工作时间内每半小时
0 0 12 ? * WED 表示每个星期三中午12点
“0 0 12 * * ?” 每天中午12点触发
“0 15 10 ? * *” 每天上午10:15触发
“0 15 10 * * ?” 每天上午10:15触发
“0 15 10 * * ? *” 每天上午10:15触发
“0 15 10 * * ? 2005” 2005年的每天上午10:15触发
“0 * 14 * * ?” 在每天下午2点到下午2:59期间的每1分钟触发
“0 0/5 14 * * ?” 在每天下午2点到下午2:55期间的每5分钟触发
“0 0/5 14,18 * * ?” 在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发
“0 0-5 14 * * ?” 在每天下午2点到下午2:05期间的每1分钟触发
“0 10,44 14 ? 3 WED” 每年三月的星期三的下午2:10和2: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触发
"0 0 12 * * ? " 每天12点运行
“0 15 10 * * ?” 每天10:15运行
“0 15 10 * * ? 2011” 2011年的每天10:15运行
“0 * 14 * * ?” 每天14点到15点之间每分钟运行一次,开始于14:00,结束于14:59。
“0 0/5 14 * * ?” 每天14点到15点每5分钟运行一次,开始于14:00,结束于14:55。
“0 0/5 14,18 * * ?” 每天14点到15点每5分钟运行一次,此外每天18点到19点每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 2007-2009” 在2007,2008,2009年每个月的最后一个星期五的10:15分运行。
“0 15 10 ? * 6#3” 每月第三个星期五的10:15分运行
2、 zone:时区,接收一个java.util.TimeZone#ID。cron表达式会基于该时区解析。默认是一个空字符串,即取服务器所在地的时区。比如我们一般使用的时区Asia/Shanghai。该字段我们一般留空。
3、 fixedDelay:上一次执行完毕时间点之后多长时间再执行。如:fixedDelay = 5000 表示上一次执行完毕时间点之后5秒再执行
4、fixedDelayString与 3. fixedDelay 意思相同,只是使用字符串的形式。唯一不同的是支持占位符。如:
@Scheduled(fixedDelayString = "5000") //上一次执行完毕时间点之后5秒再执行
占位符的使用(配置文件中有配置:time.fixedDelay=5000):
@Scheduled(fixedDelayString = "${time.fixedDelay}")
public void testFixedDelayString() {
System.out.println("Execute at " + System.currentTimeMillis());
}
5、fixedRate:上一次开始执行时间点之后多长时间再执行。如:fixedRate = 5000 //上一次开始执行时间点之后5秒再执行
6、fixedRateString 与 5. fixedRate 意思相同,只是使用字符串的形式。唯一不同的是支持占位符。
7、initialDelay 第一次延迟多长时间后再执行。如:
@Scheduled(initialDelay=1000, fixedRate=5000) //第一次延迟1秒后执行,之后按fixedRate的规则每5秒执行一次
8、initialDelayString 与 8. initialDelayString 意思相同,只是使用字符串的形式。唯一不同的是支持占位符。
以上内容输出学习使用,仅供参考!