0

0

怎么处理JVM抛出的java.lang.OutOfMemoryError: GC overhead limit exceeded_垃圾回收效率过低报警

P粉602998670

P粉602998670

发布时间:2026-03-15 15:25:31

|

127人浏览过

|

来源于php中文网

原创

GC overhead limit exceeded 本质是 JVM 的“疲劳预警”,表明 GC 花费超98%时间却仅回收≤2%内存,反映对象生命周期失控而非单纯内存不足。

怎么处理jvm抛出的java.lang.outofmemoryerror: gc overhead limit exceeded_垃圾回收效率过低报警

为什么 GC overhead limit exceeded 不是内存真不够用

这个错误本质是 JVM 的“疲劳预警”:不是堆内存彻底耗尽,而是 GC 花了太多时间(默认 98% 以上)却只回收了极少内存(默认 ≤2%),说明对象在老年代堆积、频繁晋升、或存在隐式强引用导致无法释放。它常出现在数据批量处理、缓存未清理、监听器未注销等场景,而非单纯调大 -Xmx 就能解决。

  • 默认阈值是可调的:-XX:GCTimeRatio=99(即允许 1% 时间做有用工作)、-XX:GCHeapFreeLimit=1(回收后至少剩 1% 空闲)——但掩盖问题比定位问题更危险
  • 开启 -XX:+PrintGCDetails -XX:+PrintGCTimeStamps 后,如果日志里反复出现 Full GC 且每次只回收几 MB,基本可断定是对象生命周期管理失控
  • JDK 8u40+ 默认启用该限制;JDK 11+ 仍保留,但部分 GC(如 ZGC、Shenandoah)因设计不同,几乎不会触发此错误

怎么快速定位谁在制造“GC 垃圾”

别先改参数,先抓现场。重点看三类对象:缓存未过期、静态集合持续 add、线程局部变量(ThreadLocal)未 remove。用 jstatjmap 组合比看 GC 日志更快。

  • 执行 jstat -gc <pid> 2000,观察 OU(老年代使用量)是否单向增长、OC(老年代容量)是否稳定——若 OU/OC 持续 >90%,说明对象没被回收,不是 GC 不给力,是代码没放手
  • 紧急 dump:jmap -dump:format=b,file=heap.hprof <pid>,用 VisualVMEclipse MAT 打开,按 dominator_tree 排序,重点关注 HashMapArrayListConcurrentHashMap 的实例数和 retained heap
  • 特别注意匿名内部类持有外部类引用的情况:比如在 Runnable 里直接引用了大对象,又把它塞进线程池队列,队列不消费就一直卡着

WeakReferenceSoftReference 不是万能解药

很多人一看到内存问题就加 WeakReference,结果发现根本没效果。因为它们的回收时机受 GC 类型和 JVM 实现影响极大,且不能替代正确的生命周期控制。

  • WeakReference 在下一次 GC(包括 Minor GC)时就可能被清掉,适合临时缓存,但不适合“可能还要用”的场景;SoftReference 更“软”,但 JDK 8+ 默认策略是按内存压力延迟回收,压力不大时它比强引用还顽固
  • WeakHashMap 存监听器?必须确保 key 是弱可达的——如果外面还有强引用指向同一个 key 对象,value 还是不会被释放
  • 最稳妥的方式仍是显式清理:cache.remove(key)listenerList.clear()threadLocal.remove(),而不是赌 GC

哪些 JVM 参数调整真有用,哪些只是拖延时间

调参前请确认你已看过堆转储。盲目加 -XX:-UseGCOverheadLimit 是最差选择——它只是关掉警报,不解决任何问题。

Winston AI
Winston AI

强大的AI内容检测解决方案

下载

立即学习Java免费学习笔记(深入)”;

  • 真正有效的调整:-XX:+UseG1GC(G1 对大堆和低延迟更可控)、-XX:MaxGCPauseMillis=200(让 G1 主动压缩,减少碎片)、-XX:G1HeapRegionSize=1M(避免大对象直接进老年代)
  • 对 CMS 用户:-XX:CMSInitiatingOccupancyFraction=70 可提前触发并发收集,但 JDK 9+ 已废弃 CMS,别再深陷
  • 永远不要只调 -Xmx:如果 -Xms-Xmx 差距过大,JVM 会频繁扩容堆,触发额外 GC;建议设为相等,让 GC 行为更可预测

真正难的从来不是调哪个参数,而是找到那个忘了 close() 的流、那个没 unregister 的事件监听器、那个用 static final Map 缓存了全量数据库结果的类——这些地方不会报错,只会慢慢把 GC 拖垮。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
eclipse教程
eclipse教程

php中文网为大家带来eclipse教程合集,eclipse是一个开放源代码的、基于Java的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。php中文网还为大家带来eclipse的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

197

2023.06.14

eclipse怎么设置中文
eclipse怎么设置中文

eclipse设置中文的方法:除了设置界面为中文外,你还可以为Eclipse添加中文插件,以便更好地支持中文编程。例如,你可以安装EBNF插件来支持中文变量名,或安装Chinese Helper来提供中文帮助文档。本专题为大家提供eclipse设置中文相关的各种文章、以及下载和课程。

807

2023.07.24

c语言编程软件有哪些
c语言编程软件有哪些

c语言编程软件有GCC、Clang、Microsoft Visual Studio、Eclipse、NetBeans、Dev-C++、Code::Blocks、KDevelop、Sublime Text和Atom。更多关于c语言编程软件的问题详情请看本专题的文章。php中文网欢迎大家前来学习。

625

2023.11.02

Eclipse版本号有哪些区别
Eclipse版本号有哪些区别

区别:1、Eclipse 3.x系列:Eclipse的早期版本,包括3.0、3.1、3.2等;2、Eclipse 4.x系列:Eclipse的最新版本,包括4.0、4.1、4.2等;3、Eclipse IDE for Java Developers等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

181

2024.02.23

eclipse和idea有什么区别
eclipse和idea有什么区别

eclipse和idea的区别:1、平台支持;2、内存占用;3、插件系统;4、智能代码提示;5、界面设计;6、调试功能;7、学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

153

2024.02.23

eclipse设置中文全教程
eclipse设置中文全教程

本专题整合了eclipse设置中文相关教程,阅读专题下面的文章了解更多详细操作。

117

2025.10.10

eclipse字体放大教程
eclipse字体放大教程

本专题整合了eclipse字体放大教程,阅读专题下面的文章了解更多详细内容。

158

2025.10.10

eclipse左边栏不见了解决方法
eclipse左边栏不见了解决方法

本专题整合了eclipse左边栏相关教程,阅读专题下面的文章了解更多详细内容。

120

2025.10.15

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

69

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.4万人学习

C# 教程
C# 教程

共94课时 | 11.4万人学习

Java 教程
Java 教程

共578课时 | 82.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号