李锋镝的博客

  • 首页
  • 时间轴
  • 评论区显眼包🔥
  • 左邻右舍
  • 博友圈
  • 关于我
    • 关于我
    • 另一个网站
    • 我的导航站
    • 网站地图
    • 赞助
  • 留言
  • 🚇开往
Destiny
自是人生长恨水长东
  1. 首页
  2. 后端
  3. 正文

SchedulingConfigurer详解

2026年5月15日 234点热度 0人点赞 2条评论

SchedulingConfigurer 是 Spring 定时任务的高级配置接口,用来替代简单的 @Scheduled 注解。

它的核心作用:
让定时任务支持:动态修改执行周期、程序运行中改 cron、从数据库/配置中心读取 cron 表达式,不用重启服务。


一、它解决什么问题?

  • @Scheduled(cron = "0 0/1 * * * ?"):写死在代码里,改时间必须重启
  • SchedulingConfigurer:cron 可以动态变(数据库/配置文件/Nacos 实时读取)

二、DEMO

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;

@Configuration
@EnableScheduling // 开启定时任务
public class DynamicScheduleConfig implements SchedulingConfigurer {

    // 动态 cron(实际项目从数据库/配置读取)
    private String getCron() {
        // 示例:每秒执行一次
        return "0/1 * * * * ?";
    }

    // 定时任务要执行的业务
    private void doTask() {
        System.out.println("动态定时任务执行:" + System.currentTimeMillis());
    }

    @Override
    public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {
        // 注册一个动态 cron 任务
        taskRegistrar.addTriggerTask(
            // 1. 任务内容
            () -> doTask(),

            // 2. 动态 cron 触发器
            triggerContext -> {
                // 每次执行前都会重新获取 cron → 支持动态修改
                String cron = getCron();
                return new CronTrigger(cron).nextExecutionTime(triggerContext);
            }
        );
    }
}

三、核心知识点

1. 关键方法

void configureTasks(ScheduledTaskRegistrar taskRegistrar);

所有动态任务都在这里注册。

2. 为什么能动态?

因为每次任务执行前,都会重新调用 getCron() 获取最新表达式。

你只要:

  • 把 cron 存在数据库
  • 提供一个接口修改它
  • 不用重启服务 → 定时任务自动生效

3. 多线程配置

Spring 默认定时任务是单线程!
如果任务多、执行慢,会互相阻塞。

添加线程池配置:

@Bean
public Executor taskExecutor() {
    ThreadPoolTaskScheduler executor = new ThreadPoolTaskScheduler();
    executor.setPoolSize(10); // 10个线程
    executor.setThreadNamePrefix("schedule-task-");
    executor.initialize();
    return executor;
}

然后注册任务时指定线程池:

taskRegistrar.setScheduler(taskExecutor());

四、企业级标准用法(数据库读取 cron)

  1. 建一张表:sys_schedule
    • cron 表达式
    • task_key 任务标识
    • status 状态
  2. 在 getCron() 里查库
  3. 提供接口修改 cron,实时生效

五、适用场景

✅ 动态修改定时任务周期(不用重启)
✅ 从数据库/配置中心读取 cron
✅ 复杂多任务调度
✅ 生产环境标准方案


六、和 @Scheduled 对比

方式 优点 缺点
@Scheduled 简单 cron 写死,不能动态改
SchedulingConfigurer 动态、灵活、生产级 代码稍多

除非注明,否则均为李锋镝的博客原创文章,转载必须以链接形式标明本文链接

本文链接:https://www.lifengdi.com/hou-duan/4701

相关文章

  • Spring WebFlux底层原理深度剖析-从响应式流到事件循环的全链路拆解
  • Spring WebFlux深度解析:异步非阻塞架构与实战落地指南
  • Spring事件驱动深度指南:从单机异步到亿级流量,比MQ更轻的架构神器
  • 从3秒到30毫秒!SpringBoot树形结构深度优化指南:不止于O(n)算法的全链路提速方案
  • Spring HTTP客户端演进:从RestTemplate到WebClient与RestClient
本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可
标签: Scheduled SchedulingConfigurer Spring
最后更新:2026年5月15日

李锋镝

既然选择了远方,便只顾风雨兼程。

打赏 点赞
< 上一篇
下一篇 >

文章评论

  • 皮皮社长青铜友

    不懂技术,打个水卡。破了这个0评论。 :18:

    Android
    Chrome 131.0.6778.200 中国-湖南
    2026年5月18日
    回复
    • 李锋镝管理

      @皮皮社长 沙发-。-

      macOS
      Chrome 148.0.0.0 中国
      2026年5月18日
      回复
  • 1 2 3 4 5 6 7 8 9 11 12 13 14 15 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 46 47 48 49 50 51 52 53 54 55 57 58 60 61 62 63 64 65 66 67 69 72 74 76 77 78 79 80 81 82 85 86 87 90 92 93 94 95 96 97 98 99
    取消回复
    …

    人生天地间,忽如远行客。

    那年今日(06月15日)

    • 1982年:光学专家蒋筑英逝世
    • 1843年:挪威作曲家葛利格出生
    • 1667年:人类历史上首次输血治疗在法国进行
    • 1594年:法国画家尼古拉·普桑出生
    • 1330年:威尔士亲王黑太子爱德华出生
    • 更多历史事件
    最新 热点 随机
    最新 热点 随机
    Claude-HUD 使用文档 Kratos+ —— Kratos 主题二次开发记录 译文:如何将单体应用拆解为微服务 codebase-memory-mcp 极简完整使用指南 Claude Haiku 4.5、Claude Sonnet 4.6、Claude Opus 4.7 区别以及各自的新特性 SchedulingConfigurer详解
    AI时代,个人技术博客的出路在哪里?这个域名注册整整十年了,十年时间,真快啊WordPress实现用户评论等级排行榜插件WordPress网站换了个字体,差点儿把样式换崩了做了一个WordPress文章热力图插件千万级大表新增字段实战指南:告别锁表与业务中断
    分布式事务的 N 种实现 MapStruct深度解析:从原理到实战,告别BeanUtil的性能与安全痛点 k8s + docker + Jenkins使用Pipeline部署SpringBoot项目时Jenkins错误集锦 项目中慎用 CompletableFuture:这些坑你必须知道 Spring中@NotNull、@NotBlank、@NotEmpty的区别 Idea激活码
    最近评论
    博客集市 发布于 3 周前(05月26日) 博客组织申请友链 网站名称: 博客集市 网站地址: https://cnb.cool/Blog_...
    李锋镝 发布于 4 周前(05月18日) 沙发-。-
    皮皮社长 发布于 4 周前(05月17日) 不懂技术,打个水卡。破了这个0评论。 :18:
    林羽凡 发布于 2 个月前(04月27日) 没毛病,主要是禁用描述,和可以做什么的描述,哪些命令能用,哪些不能用,在什么情况下问我之类的。
    老张博客 发布于 2 个月前(04月02日) 这个真的是保姆级教程了。
    标签聚合
    架构 WordPress SQL 多线程 AI MCP IDEA JVM 日常 MySQL 分布式 AI编程 ElasticSearch SpringBoot K8s 设计模式 Redis JAVA 数据库 Spring
    友情链接
    • Blogs·CN
    • Honesty
    • Mr.Sun的博客
    • 临窗旋墨
    • 哥斯拉
    • 彬红茶日记
    • 志文工作室
    • 懋和道人
    • 拾趣博客导航
    • 搬砖日记
    • 旧时繁华
    • 林羽凡
    • 瓦匠个人小站
    • 皮皮社
    • 知向前端
    • 蜗牛工作室
    • 韩小韩博客
    • 风渡言

    COPYRIGHT © 2026 lifengdi.com. ALL RIGHTS RESERVED.

    域名年龄

    Theme Kratos+ By Dylan Li

    津ICP备2024022503号-3

    京公网安备11011502039375号