基于springboot的定时任务实现(非分布式)

2021-03-19 06:24

阅读:578

标签:code   edr   type   schedule   public   ram   Fix   rate   成功   

1. 核心注解

在springboot项目中我们可以很方便地使用spring自己的注解@Scheduled@EnableScheduling配合来实现便捷开发定时任务。

@EnableScheduling注解的作用是发现注解@Scheduled的任务并后台执行,此注解可以加到启动类上也可以加到执行调度任务类上。

经测试,当有多个包含定时任务的类时,@EnableScheduling注解加在其中一个类上就可以保证所有定时任务的成功实现。

注意:定时任务的类上还需要配合使用@Configuration@Component注解,这两个注解都可以。

2. 实例代码:

2.1 @EnableScheduling加在启动类上;

import com.my.common.util.DateUtil;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

import java.util.Date;

/**
 * @description:
 * @author: Karl
 * @date: 2020/10/10
 */
@Component
public class TestSchedule01 {

    @Scheduled(cron = "0 * * * * ? ")
    public void test() {
        System.out.println("我是定时任务01,我执行了" + DateUtil.formatDateByDateTime(new Date()));
    }
}
import com.my.common.util.DateUtil;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

import java.util.Date;

/**
 * @description:
 * @author: Karl
 * @date: 2020/10/10
 */
@Configuration
public class TestSchedule02 {

    @Scheduled(cron = "1 * * * * ? ")
    public void test() {
        System.out.println("我是定时任务02,我执行了" + DateUtil.formatDateByDateTime(new Date()));
    }
}
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.scheduling.annotation.EnableScheduling;

@EnableScheduling
@SpringBootApplication
public class DemoApplication {

    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
    }

}

2.1 @EnableScheduling加在任务类上;

import com.my.common.util.DateUtil;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

import java.util.Date;

/**
 * @description:
 * @author: Karl
 * @date: 2020/10/10
 */
@Component
@EnableScheduling
public class TestSchedule01 {

    @Scheduled(cron = "0 * * * * ? ")
    public void test() {
        System.out.println("我是定时任务01,我执行了" + DateUtil.formatDateByDateTime(new Date()));
    }
}
import com.my.common.util.DateUtil;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

import java.util.Date;

/**
 * @description:
 * @author: Karl
 * @date: 2020/10/10
 */
@Configuration
public class TestSchedule02 {

    @Scheduled(cron = "1 * * * * ? ")
    public void test() {
        System.out.println("我是定时任务02,我执行了" + DateUtil.formatDateByDateTime(new Date()));
    }
}

注意:只需要在其中一个任务类上加上@EnableScheduling注解,所有的定时任务就都可以正常运行。

3. @Scheduled的几种用法

@Scheduled这个注解支持3种定时方式,即:cron、fixedRate和fixedDelay

cron:是以表达式的形式来表示时间,最常见;

fixedRate:表示Scheduled隔多长时间调用一次,不管任务是否执行完;

fixedDelay:表示该任务执行完后隔多长时间再调用;

基于springboot的定时任务实现(非分布式)

标签:code   edr   type   schedule   public   ram   Fix   rate   成功   

原文地址:https://www.cnblogs.com/datangguanjunhou/p/13948319.html


评论


亲,登录后才可以留言!