SpringBoot(十七)-- 定时任务

日常开发中,经常会使用定时任务来执行跑批,springboot默认已经帮助我们整合了定时任务。

参考:https://blog.csdn.net/u013845177/article/details/78244524

1.启动类启用定时

在启动类上添加@EnableScheduling

2.创建定时任务实现类

package com.xsjt.timer;
import java.text.SimpleDateFormat;
import java.util.Date;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
/**  
 * ClassName:SchedulerTask 
 * 定时任务
 * Date:     2018年4月22日 下午5:48:34
 * @author   Joe  
 * @version    
 * @since    JDK 1.8
 */
@Component
public class SchedulerTask {

    /**
     * executeTask:(每5秒中执行一次).  
     * @author Joe
     * Date:2018年4月22日下午5:51:34
     */
    @Scheduled(cron = "0/5 * * * * *")
    public void executeTask() {
        System.out.println("--executeTask方法,每隔5秒执行一次,当前时间:" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
    }
    
    /**
     * executeTask2
     * 在上一次执行完之后等待xxx毫秒(xxx就是fixedDelay = 5000中的5000)再执行,循环下去 ,
     * 上一次执行多久都没关系 ,反正上一次执行完后xxx毫秒我才执行 
     * @author Joe
     * Date:2018年4月22日下午7:03:11
     */
    @Scheduled(fixedDelay = 5000)
    public void executeTask2() {
        System.out.println("**executeTask2方法, 执行一次,当前时间:" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
    }
    
    /** 
     * fixedRate 举个例子:比如:假设有5个执行时间点 间隔是5000毫秒:分别是: 
     * T1:14:00:00 
     * T2:14:00:05 
     * T3:14:00:10 
     * T4:14:00:15 
     * T5:14:00:20 
     * 如果T1执行时间花了4秒,也就是到了14:00:04,那么你会看到14:00:05分就开始执行了T2,很正常,此时T1结束时间和T2开始时间只差1000毫秒,没毛病 
     * 如果T1执行时间花了8秒,怎么办?这时T1执行完的时间是14:00:08,已经覆盖了T2的时间,T2在14:00:05到14:00:08是等等状态。现在是14:00:08,看起来接着是T3执行, 
     * 但实际不是,而是立马执行T2,立马执行T2,立马执行T2(T2说:我不管,T1搞我超时了,我无论也是执行),这时你会发现T2的执行时间(也就是第2次执行时间 )是:14:00:08,真的是立马。。。 
     * 如此类推,只要时执行时间被覆盖了的,到它了就立马执行 
     */  
    @Scheduled(fixedRate = 5000)
    public void executeTask3() {
        System.out.println(">>executeTask3方法, 一次,当前时间:" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
        try {
            Thread.sleep(8000);
        } catch (InterruptedException e) {
            e.printStackTrace();  
        }
    }
}

 3.源码下载

https://gitee.com/xbq168/spring-boot-learn

 

posted @ 2018-04-22 19:17  小葱拌豆腐~  阅读(789)  评论(0编辑  收藏  举报