springboot中动态基于接口SchedulingConfigurer的定时任务

本文介绍基于接口(SchedulingConfigurer)的定时任务,通过添加TriggerTask循环读取数据库设置的执行周期并执行任务。使用lambda表达式,启动Spring Boot后按数据库设定时间执行,修改时间无需重启。但数据库修改格式错误时,需重启项目恢复,定时任务间隔从MySQL数据库获取。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

基于接口(SchedulingConfigurer)的定时任务

代码中添加的TriggerTask,目的是循环读取我们在数据库设置好的执行周期,以及执行相关定时任务的内容

下面的方法中是用来lambda表达式

/**
 * @ Author zhangsf
 * @CreateTime 2019/5/1 - 4:54 PM
 */
package com.zsf.spider.controller;

import org.apache.commons.lang3.StringUtils;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.scheduling.annotation.SchedulingConfigurer;
import org.springframework.scheduling.config.ScheduledTaskRegistrar;
import org.springframework.scheduling.support.CronTrigger;

import static com.zsf.spider.util.DateUtil.now;


@Configuration      //1.主要用于标记配置类,兼备Component的效果。
@EnableScheduling   // 2.开启定时任务
public class DynamicScheduleTask implements SchedulingConfigurer {

    @Mapper
    public interface CronMapper {
        @Select("select cron from cron limit 1")
        public String getCron();
    }

    @Autowired      //注入mapper
    @SuppressWarnings("all")
    CronMapper cronMapper;
    /**
     * 执行定时任务
     */
    @Override
    public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {
        taskRegistrar.addTriggerTask(
                //1.添加任务内容(Runnable)
                //其中configureTasks()是需要执行的任务
                () -> {System.out.println("执行动态定时任务: " + now();
                      configureTasks();},
                //2.设置执行周期(Trigger)
                triggerContext -> {
                    //2.1 从数据库获取执行周期
                    String cron = cronMapper.getCron();
                    System.out.println("cron="+cron);
                    //2.2 合法性校验.
                    if (StringUtils.isEmpty(cron)) {
                        // Omitted Code ..
                    }
                    //2.3 返回执行周期(Date)
                    return new CronTrigger(cron).nextExecutionTime(triggerContext);
                }
        );
    }

}

启动了springboot之后就回发现每次执行的时间差是数据库中设定的定时任务

而且当我将数据库中执行的时间由5s改为了3s之后,并不需要重启springboot

注意: 如果在数据库修改时格式出现错误,则定时任务会停止,即使重新修改正确;此时只能重新启动项目才能恢复。

其中动态获取定时任务间隔是从MySQL数据库中获取

DROP DATABASE IF EXISTS `blog`;
CREATE DATABASE `socks`;
USE `SOCKS`;
DROP TABLE IF EXISTS `cron`;
CREATE TABLE `cron`  (
  `cron_id` varchar(30) NOT NULL PRIMARY KEY,
  `cron` varchar(30) NOT NULL  
);
INSERT INTO `cron` VALUES ('1', '0/5 * * * * ?');

插入之后

将数据库中间隔时间改为3秒的时候

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhangvalue

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值