java面试OOM汇总

在正式 Minor GC 前,JVM 会先检查新生代中对象,是比老年代中剩余空间大还是小。假如 Minor GC之后 Survivor 区放不下剩余对象,这些对象就要进入老年代 老年代剩余空间大于新生代中的对象大小,那就直接 Minor GC, GC 完 Survivor 不够放,老年代也绝对够放;老年代剩余空间小于新生代中的对象大小,这个时候就要查看是否启用了老年代空间分配担保规则

触发 Full GC的条件

  1. 调用 System.gc() 建议 JVM 进行 Full GC

  2. CMS 并发失败,使用 Serial Old 收集

  3. 空间分配担保失败

  4. 老年代空间不足

Java 堆溢出

在 Java 堆中没有内存完成实例分配,并且堆也无法再扩展时, Java 虚拟机将会抛出

OutOfMemoryError 异常

溢出原因

应用程序保存了无法被GC回收的对象

排查解决思路

查找关键字报错信息 java.lang.OutOfMemoryError: Java heap space

使用内存映像分析工具 Jprofiler,对 Dump 出来的堆储存快照进行分析,分析清楚是内存泄漏还

是内存溢出

如果是内存泄漏,可进一步通过工具查看泄漏对象到 GC Roots 的引用链,修复应用程序中的内存

泄漏

如果不存在泄漏,先检查代码是否有死循环,递归等,再考虑用 -Xmx 增加堆大小

栈溢出

如果线程请求的栈深度大于虚拟机所允许的深度,将抛出 StackOverflowError 异常; 如果Java虚拟机

栈容量可以动态扩展,当栈扩展时无法申请到足够的内存会抛出 OutOfMemoryError 异常

溢出原因

在单个线程下,无论是由于栈帧太大还是虚拟机栈容量太小,当内存无法分配的时候,抛出

StackOverflowError 异常

不断地建立线程的方式会导致内存溢出

排查解决思路

查找关键报错信息,确定是 StackOverflowError 还是 OutOfMemoryError

如果是 StackOverflowError,检查代码是否递归调用方法等

如果是 OutOfMemoryError,检查是否有死循环创建线程等,通过-Xss 降低的每个线程栈大小的

容量

方法区溢出

运行时产生大量的类,填满方法区,或者当常量池无法再申请到内存时会抛出OutOfMemoryError 异常

溢出原因

使用CGLib 生成了大量的代理类,导致方法区被撑爆

在Java7 之前,频繁的错误使用 String.intern() 方法

排查解决思路

检查是否使用 CGLib 生成了大量的代理类

检查代码是否频繁错误得使用 String.intern() 方法

直接内存溢出

直接内存也被频繁地使用,也可能导致OOM

溢出原因

本机直接内存的分配虽然不会受到 Java 堆大小的限制,但是受到本机总内存大小限制

NIO程序中,使用 ByteBuffer.allocteDirect(capability) 分配的是直接内存,可能导致直接内存溢

直接内存由 -XX:MaxDirectMemorySize 指定,如果不指定,则默认与Java堆最大值(-Xmx指定)

一样

排查解决思路

检查代码是否恰当

检查 JVM参数 -Xmx,-XX:MaxDirectMemorySize 是否合理

相关推荐
草履虫建模14 小时前
力扣算法 1768. 交替合并字符串
java·开发语言·算法·leetcode·职场和发展·idea·基础
naruto_lnq17 小时前
分布式系统安全通信
开发语言·c++·算法
qq_2975746717 小时前
【实战教程】SpringBoot 实现多文件批量下载并打包为 ZIP 压缩包
java·spring boot·后端
老毛肚17 小时前
MyBatis插件原理及Spring集成
java·spring·mybatis
学嵌入式的小杨同学17 小时前
【Linux 封神之路】信号编程全解析:从信号基础到 MP3 播放器实战(含核心 API 与避坑指南)
java·linux·c语言·开发语言·vscode·vim·ux
lang2015092817 小时前
JSR-340 :高性能Web开发新标准
java·前端·servlet
Re.不晚17 小时前
Java入门17——异常
java·开发语言
缘空如是18 小时前
基础工具包之JSON 工厂类
java·json·json切换
精彩极了吧18 小时前
C语言基本语法-自定义类型:结构体&联合体&枚举
c语言·开发语言·枚举·结构体·内存对齐·位段·联合
追逐梦想的张小年18 小时前
JUC编程04
java·idea