SpringBoot项目要想创建定时调度任务,首先需要在其启动器类上面添加注解@EnableScheduling 注解开启功能,自动扫描。
@SpringBootApplication
@EnableScheduling //添加此注解,@EnableScheduling 注解开启功能,自动扫描
public class ScheduledApplication {
public static void main(String[] args) {
SpringApplication.run(ScheduledApplication.class, args);
}
}
创建定制调度任务类
package com.example.demo;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
/**
* @Auther:wyb
* @Date:2019/6/10
* @Description:com.example.demo
* @Version:1.0
*/
@Component
@Configuration //1.主要用于标记配置类,兼备Component的效果。
@EnableScheduling // 2.开启定时任务
@PropertySource("classpath:/task-config.ini") // 3.配置文件位置
public class TaskTest {
@Scheduled(cron = "${cron}")
public static void doThis(){
System.out.println("定时调度启动啦。。。");
}
}
在classpath下创建task-config.ini文件,配置文件代码:(每分钟执行一次)
cron= * */1 * * * ?
cron表达式:
是一个字符串,分为6或7个域,每两个域之间用空格分隔,其语法格式为:"秒域 分域 时域 日域 月域 周域 年域",年域可以不写。这里cron表达式不做详解,有需要了解的童鞋可以参考https://www.zhyd.me/article/43
分布式下重复执行的解决方案:
可以通过redis的分布式锁保证,redis分布式锁是通过setnx命令实现的。该命令的作用是,当向redis中存入一个值时,会先判断该值对应的key是否存在,如果存在则返回0,如果不存在,则将该值存入redis并返回1。(但是在分布式跨时区部署的时候,依然无法避免重复执行)