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

Java应用启动慢、接口超时、频繁Full GC?别再把锅甩给JVM了!

问题现场:扩容反而引发告警风暴

最近,我们的服务在业务高峰进行一次常规扩容,新增了两个POD。本以为能平滑分担流量,结果启动后不久,P1级别接口超时告警频繁Full GC告警接连爆发。

从监控图可以清晰看到:

  • 新启动的POD在刚接收流量的前几分钟,接口平均耗时飙升到秒级;
  • JVM的Full GC次数陡增,Old区几乎被打满;
  • 运行几分钟后,一切又逐渐恢复正常。

这种现象并非第一次出现,应用启动时也会出现类似的现象。扩容或者重启变成“陪葬”,到底是谁在作祟?

结论先行:@RefreshScope的滥用

团队没有止步于表象,而是深入Spring Cloud源码,并结合Demo进行复现,最终锁定了“真凶”——@RefreshScopel滥用。

@RefreshScope的初始化“陷阱”

在我们的应用中,大量Controller、Service类上都标注了@RefreshScope,初衷是为了实现Nacos配置的热更新。然而,这个注解的初始化行为却暗藏玄机:

  • 普通Bean:在Web容器初始化完成之前实例化,服务注册到Nacos时,所有依赖都已就绪。
  • @RefreshScope Bean:采用懒加载模式,它要等到ContextRefreshedEvent事件(该事件发生在Web容器初始化之后)才会触发实例化。

也就是说,当Nacos完成服务注册、上游流量开始涌向新POD时,被@RefreshScope修饰的那些Bean(包括Controller、Service)可能根本还没创建完成!

锁粒度惊人:读写锁阻塞所有请求

翻看RefreshScope的源码,发现它的get()destroy()方法都使用了读写锁。当请求并发进入时,大量线程需要等待锁释放,等到Bean实例化完成才能继续。

这个锁的粒度是整个Scope级别,相当于把一个Controller里所有接口、甚至多个Service都串行化了。启动瞬间的高并发,直接导致请求排队、响应超时。

运行时配置变更也是“定时炸弹”

你以为只在启动时卡?太天真了。

当Nacos配置发生变更时,RefreshScope会执行refreshAll()——销毁所有被@RefreshScope标注的Bean实例,但并不立即重建。等到下一次请求进来时,再走一遍加锁、实例化的重流程。于是,每次配置发布,都可能引发新一轮的请求阻塞和P1告警。

抽丝剥茧:源码分析

RefreshScope注解Bean初始化

SpringCloud提供的服务注册抽象类AbstractAutoServiceRegistration通过监听Web容器的初始化完成事件注册服务,注册中心客户端(不限于Nacos)实现这个抽象类就会在 Web容器初始化完成后向注册中心注册服务。

Nacos的服务注册NacosAutoServiceRegistration实现了这个抽象类 ,所以Nacos客户端会在Web容器初始化完成后注册服务 。

业务Bean的实例化过程分为两类

  • 没有@RefreshScope修饰的Bean初始化过程

初始化完成后,在onRefresh()方法中初始化Web容器Bean

容器Ben初始化完成,发布容器初始化完成事件:ServletWebServerInitializedEvent,ServletWebServerInitializedEvent继承自WebServerInitializedEvent事件,此后Nacos客户端注册服务

  • 被@RefreshScope修饰的Bean初始化过程
    被@RefreshScope修饰的Bean使用RefreshScope类监听ContextRefreshedEvent事件初始化Bean

ContextRefreshedEvent事件发生在WebServerInitializedEvent之后,此时初始化Bean时,服务已经被注册到注册中心,请求已经进来,但Bean还在初始化中,造成服务启动时接口响应慢、GC异常

RefreschScope注解Bean实现配置热更新

在上面的源码分析中知道@RefreshScope修饰的Bean使用RefreshScope类监听ContextRefreshedEvent事件初始化Bean,那它是如何做到热更新配置的?Nacos的配置中心Client类NacosContextRefresher在Spring容器发布ApplicationReadyEvent事件时预注册了一个AbstractSharedListener

在AbstractSharedListener的中发布RefreshEvent事件

http://www.gsyq.cn/news/1587093.html

相关文章:

  • Android Studio中文汉化终极指南:5分钟打造母语级开发环境
  • ROS嵌入式部署实战:在Jetson/RPi上稳定运行机器人系统
  • 服装贴口袋工序自动化科普:慧拿线上激光模板机全面解析
  • AI案例:选AI还是选人
  • 白领 16 亿 tokens
  • Fastjson反序列化漏洞:从原理到实战防护的Java安全必修课
  • 从高维数据中提取本质特征:秩提取与鲁棒子空间设计实践
  • 银河麒麟V10 SP3 源码编译部署 PostgreSQL 18.4
  • 跨平台资源下载神器:5分钟掌握res-downloader完整使用指南
  • 计算机小程序毕设实战-基于 SpringBoot+UniApp 的区域文旅(冀鲁豫)旅行推荐系统设计与实现 基于 SpringBoot+UniA【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • 智人曾经这样灭绝猛犸象:AI入侵与行业灭绝
  • Loop Engineering :从提示词工程到循环工程,AI 编程的范式革命
  • 终极免费解锁:如何用Ohook完整激活Microsoft 365所有功能
  • 电梯里同事问我:“你觉得RAG落地最难的地方在哪?”,我愣了,保安转头:“我以前干过,主要就文档预处理、召回质量、生成忠诚度”
  • 终极SPT-AKI存档编辑器:免费开源的游戏进度管理神器
  • 深度剖析SQL注入攻防:从MySQL语法特性到多层防护体系
  • 淘宝闪购 AI 应用研发二面,我笑了!!!
  • 大模型AI智能客服系 AI智能客服系统 - 全功能详细介绍
  • 幼小衔接友好英语启蒙app深度实测,和小学教材主题同步对接
  • 遗传算法求解背包问题:零基础实战指南
  • 我翻脸了:“怎么现在面开发岗也要了解Transformer?”,面试官:“那你知道上下文窗口为什么有上限?为什么长对话质量越来越差吗?”
  • RLHF实战指南:用人类偏好对齐大模型意图
  • 前端构建性能优化
  • Perplexity版权风波:RAG架构下的AI数据合规实战指南
  • OpenCR深度解析:ROS机器人实时控制中枢入门指南
  • 2026年最简单易用的10款 OpenClaw 国产替代品:深度评测与对比
  • Notepad--:国产轻量编辑器,自带代码对比,免费替代Notepad++和Beyond Compare!
  • 如何快速恢复Godot项目:逆向工程的完整指南
  • AI浏览器真相:识别虚假技术概念与真实落地实践
  • XZ7110工作电压2.8-6V 输出电流1A 带使能控制的LED恒流驱动芯片