SpringBoot专栏:集成定时ScheduledTasks任务,刷新概念了_14讲

SpringBoot专栏:集成定时ScheduledTasks任务,刷新概念了_14讲_第1张图片

开场白

昨天整理SpringBoot集成Redist缓存,采坑一天 ,汇总了下 。

文章链接https://www.toutiao.com/i6640003656995308045/

通过整理我们会发现简单的知识系统梳理也不是一件很顺利编码的事,所以只有不断的总结方可提升,才能共享更多的优质资源。 

这篇我们开启springboot做调度任务的集成,当我们使用SpringMvc集成定时任务的时候,会发现异常的繁琐,那么SpringBoot如何去集成的呢,这篇刷新对“简单”的认识。

Demo快速构建

1. 创建一个Springboot工程,程序入口加@EnableScheduling,开启调度任务。

SpringBoot专栏:集成定时ScheduledTasks任务,刷新概念了_14讲_第2张图片

2.创建定时任务ScheduledTasksSimple类(来个最简单demo)
  创建一个定时任务,每过2s在控制台打印日志信息。

@Component
public class ScheduledTasksSimple {
    private static final Logger log = LoggerFactory.getLogger(ScheduledTasksSimple.class);
    DateFormat dateFormat=new SimpleDateFormat("YYYY-MM-dd hh:mm;ss");
    /**
     * @Scheduled(fixedRate = 2000) 每隔2秒执行一次:上一次开始执行时间点之后5秒再执行
     * @Scheduled(fixedDelay = 2000) :上一次执行完毕时间点之后2秒再执行
     */
    @Scheduled(fixedRate = 2000)
    public void reportCurrentTime() {
        log.info("我是定时任务我开始运行...{}",dateFormat.format(new Date()));
    }

}

划重点:
方法上加@Scheduled注解,开启一个调度任务(此方法的)。

3.测试开始

启动springboot项目后,控制台如下日志..(每隔2秒执行一次)

2018-12-29 11:53:12.394  INFO 30904 --- [pool-1-thread-1] com.limp.tasks.ScheduledTasksSimple      : 我是定时任务我开始运行...2018-12-29 11:53;12
2018-12-29 11:53:14.394  INFO 30904 --- [pool-1-thread-1] com.limp.tasks.ScheduledTasksSimple      : 我是定时任务我开始运行...2018-12-29 11:53;14
2018-12-29 11:53:16.395  INFO 30904 --- [pool-1-thread-1] com.limp.tasks.ScheduledTasksSimple      : 我是定时任务我开始运行...2018-12-29 11:53;16
2018-12-29 11:53:18.394  INFO 30904 --- [pool-1-thread-1] com.limp.tasks.ScheduledTasksSimple      : 我是定时任务我开始运行...2018-12-29 11:53;18

End

上面在springboot创建定时任务比较简单,需要注意@EnableScheduling(程序的入口)和@Scheduled(定时方法)即可

但是需要深入了解可能会发现

1.定时任务@Scheduled(fixedRate = 2000)和@Scheduled(fixedDelay = 2000)到底有什么区别?

2.@Scheduled(cron=" /5 ")注解通过cron表达式定义规则,有木有更加便捷的方式了解cron表达式?

3.上面会涉及并问题吗?

4.定时任务有什么业务场景?

...

需要注意的问题很多,这篇先有一个简单入门,下班前会汇总一篇高阶实战篇(需要精心整理后再共享给大家)。

坚持写作1个月了,现在发现朋友的一次转发、关注是对本文的最大支持,鼓励下呗

 


 

你可能感兴趣的:(Spring,Boot,SpringBoot入门)