Spring Boot定时任务以及执行时间

最近项目中一些外部接口需要定时扫描表中数据,定时发送,由于项目框架是springboot的,故首先考虑使用spring内部配置实现定时任务,主要考虑到方便快捷

springboot创建定时任务主要有三种方式:
1.基于注解(@Scheduled)
2.基于接口(SchedulingConfigurer)
3.基于注解的多线程定时任务

基于注解使用

package com.club.business.scheduletask;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.scheduling.annotation.Scheduled;
import java.time.LocalDateTime;

/**
 * 定时任务配置类
 *
 * @Configuration 主要用于标记配置类,兼备Component的效果
 * @EnableScheduling 开启定时任务
 * @author NanCheng
 * @date 2021-04-12
 */
@Configuration
@EnableScheduling
public class MyScheduleTask {

    private static final Logger log = LoggerFactory.getLogger(MyScheduleTask.class);

    /**
     * 添加定时任务(指定定时任务执行时间间隔,例如:5秒)
     * 或使用fixedRate @Scheduled(fixedRate=5000)也表示每5秒执行一次
     */
    @Scheduled(cron = "0/5 * * * * ?")
    private void configureTasks() {
        /**
         * 此处可添加执行任务中的业务逻辑
         */
        log.info("执行静态定时任务时间: " + LocalDateTime.now());
    }
}

基于接口使用

/**
* 基于接口方式的定时任务
* @Configuration 主要用于标记配置类,兼备Component的效果
* @EnableScheduling 开启定时任务
* 注意:需要实现接口 SchedulingConfigurer
* @author NanCheng
* @date 2021-04-12
*/
@Configuration
@EnableScheduling
public class DynamicScheduleTask implements SchedulingConfigurer {

    @Autowired
    CronMapper cronMapper;

    /**
     * 重写定时任务方法
     */
    @Override
    public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {
		/**添加任务*/
        taskRegistrar.addTriggerTask(
        		/**
        		* 添加需要执行的业务逻辑
        		*/
                () -> System.out.println("执行动态定时任务: " + LocalDateTime.now().toLocalTime()),
                /**设置执行任务的周期*/
                triggerContext -> {
                    /**从数据库获取配置的执行周期(此处采用)
                    * 可以将执行周期配置在配置文件中获取
                    */
                    String cron = cronMapper.getCron();
                    /**判断取出的周期配置是否为空*/
                    if (StringUtils.isBlank(cron)) {
                        /**数据为空则执行重新获取逻辑*/
                    }
                    /**最后返回执行周期*/
                    return new CronTrigger(cron).nextExecutionTime(triggerContext);
                }
        );
    }
}

基于注解的方式实现多线程定时使用

/**
* 基于注解的方式实现多线程定时任务
* @Configuration 主要用于标记配置类,兼备Component的效果
* @EnableScheduling 开启定时任务
* @EnableAsync 开启多线程
* 注意:需要实现接口 SchedulingConfigurer
* @author NanCheng
* @date 2021-04-12
*/
@Configuration
@EnableScheduling
@EnableAsync
public class MultithreadScheduleTask {
		
		/**
		* 使用 fixedDelay 的方式设置时间间隔为1秒
		* @Async注解开启一个线程,重要
		*/
        @Async
        @Scheduled(fixedDelay = 1000)
        public void first() throws InterruptedException {
            System.out.println("第一个定时任务开始 : " + LocalDateTime.now().toLocalTime() + "\r\n线程 : " + Thread.currentThread().getName());
            System.out.println();
            Thread.sleep(1000 * 10);
        }

        @Async
        @Scheduled(fixedDelay = 2000)
        public void second() {
            System.out.println("第二个定时任务开始 : " + LocalDateTime.now().toLocalTime() + "\r\n线程 : " + Thread.currentThread().getName());
            System.out.println();
        }
    }

附录

关于定时时间的设置方式如下:
CronTrigger配置完整格式为: [秒] [分] [小时] [日] [月] [周] [年]
示例:

0 0 10,14,16 * * ? 每天上午10点,下午2点,40 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:102: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触发
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值