@Scheduled定时任务现状与改进

项目场景:

定时任务现状:每个项目都会有一些配置信息,这些信息我们是都放在一个配置服务中,这个服务会定时从配置表中加载所有配置存入本地JVM内存,以供调用方获取(调用方集成了配置服务的SDK,每隔五分钟都会来拉取自身应用的配置)

配置服务每隔五分钟都会去全量拉取配置表然后替换本地内存中的旧配置,而定时任务使用的是基于@Scheduled注解(基于此改造后支持集群环境下单节点执行),然后搭配 cron 表达式

例如:@Scheduled(cron = "0 0/5 * * * ? ") 此配置含义为:分钟为5以及5的倍数 秒钟为0时执行


问题描述

生产中随着配置服务的实例增多,流量监控多出了许多毛刺

注:(此图为已将调用方的cron给错开后所呈现,如是最初版本将每5分钟会"人为"造就一大波请求)


解决方案:

改造一:

因生产上每5分钟配置中心的应用就会迎来一大波请求,导致压力剧增,并且非5分钟的时间段配置中心是没有什么请求

据此情况,进行了第一轮改造:

将各个调用配置中心的应用 配置不同的cron表达式,例如:

A、B服务调用配置中心获取机构白名单配置的定时任务就修改为以下表达式A:25*/4***? B:207/4x**?

这样配置固然是将各个应用获取配置的时间给错开,但是并没有从根本上解决问题

改造二:

对于此类需要去配置中心加载参数的定时任务,采用fixedInterval方式,即以上次执行终点起点来计算下次执行起点时间,这样生产个应用的实例的执行时间就从根本上错开了(且可以人为控制实例的部署时间间隔)

附上@Scheduled各参数描述:@Scheduled注解各参数详解 - 简书 (jianshu.com)

相关推荐
lzp07913 分钟前
元数据驱动开发 - 面向对象编程思想的补充(上)
spring boot·后端·ui
方也_arkling8 小时前
【Java-Day08】static / final / 枚举
java·开发语言
橙淮8 小时前
Spring Bean作用域与生命周期全解析
java·spring
Chengbei118 小时前
一站式源码安全检测工具、云安全 / APP / 小程序源码敏感信息递归多层目录扫描AK、JWT、手机号、身份证等敏感信息
java·开发语言·安全·web安全·网络安全·系统安全·安全架构
llz_1128 小时前
web-第一次课后作业
java·开发语言·idea
秋99 小时前
Java项目运行5天左右自动宕机:系统性定位与解决方案
java·开发语言·python
小江的记录本9 小时前
【JVM虚拟机】垃圾回收GC:垃圾收集器:CMS:核心原理、回收流程、优缺点、废弃原因(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·面试·maven
DIY源码阁9 小时前
JavaSwing学生成绩管理系统 - MySQL版
java·数据库·mysql·eclipse
basketball61610 小时前
C++ NULL 和 nullptr 区别 以及 nullptr 的核心实现
java·开发语言·c++
JAVA面经实录91711 小时前
MyBatis面试题库
java·mybatis