当前位置: 首页 > news >正文

@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)

http://www.lryc.cn/news/273453.html

相关文章:

  • python+selenium爬虫笔记
  • 【LMM 009】MiniGPT-4:使用 Vicuna 增强视觉语言理解能力的多模态大模型
  • SpringBoot学习(三)-整合JDBC、Druid、MyBatis
  • 如何选择合适的语音呼叫中心?
  • 使用qtquick调用python程序
  • 【Axure高保真原型】树形表格_多选效果
  • 【Filament】加载obj和fbx模型
  • [USACO04OPEN] The Cow Lineup
  • 软件工具集合
  • C#利用openvino部署PP-TinyPose人体姿态识别
  • MindSpore Serving与TGI框架 の 对比
  • 两阶段提交协议三阶段提交协议
  • 6-Docker Compose-tomcat application(指定官方镜像)
  • 宝塔安装的imagemagick不能用,必须自己手动安装
  • 解决在test以外的目录下导入junit无效
  • docker 在线安装mysql 8.0.21版本
  • WPF DatePicker与Calendar的使用和样式修改
  • 从0开始python学习-40.通过正则表达式/json进行接口关联
  • 【React系列】高阶组件
  • 听GPT 讲Rust源代码--src/tools(38)
  • .NET C# 如何获取object对象的数据
  • 使用IDEA创建使用 JDK8 的 2.x.x 版本的 Spring Boot 项目以及 Spring Boot 项目如何修改JDK版本
  • 游戏服务器整体架构思考
  • labelme 标注的数据集转化为Mask-Rcnn适用的数据集
  • x-cmd pkg | tig - git 文本模式界面
  • 信息论与编码期末复习——概念论述简答题(一)
  • [Kubernetes]4. 借助腾讯云TKE快速创建Pod、Deployment、Service部署k8s项目
  • 二叉排序树的创建、插入、查找和删除【数据结构】
  • 【管理篇 / 恢复】❀ 07. macOS下用命令刷新固件 ❀ FortiGate 防火墙
  • 工作纪实40-使用redis的几种姿势