无法在 Java 堆中分配对象
吞吐量增加
应用程序无意中保存了对象引用,对象无法被 GC 回收
应用程序过度使用 finalizer。finalizer 对象不能被 GC 立刻回收。finalizer 由结束队列服务的守护线程调用,有时 finalizer 线程的处理能力无法跟上结束队列的增长
单位对应:GB -> G, g;MB -> M, m;KB -> K, k
使用?-Xmx?增加堆大小
修复应用程序中的内存泄漏
使用?-Xmx?增加堆大小
使用?-XX:-UseGCOverheadLimit?取消 GC 开销限制
修复应用程序中的内存泄漏
使用?-Xmx?增加堆大小
修复应用程序中分配巨大数组的 bug
Perm gen 空间包含:
类的名字、字段、方法
与类相关的对象数组和类型数组
JIT 编译器优化
当 Perm gen 空间用尽时,将抛出异常。
使用?-XX: MaxPermSize?增加 Permgen 大小
不重启应用部署应用程序可能会导致此问题。重启 JVM 解决
通过命令行设置?-XX: MaxMetaSpaceSize?增加 metaspace 大小
取消?-XX: maxmetsspacedize
减小 Java 堆大小,为 MetaSpace 提供更多的可用空间
为服务器分配更多的内存
可能是应用程序 bug,修复 bug
为机器分配更多的内存
减少 Java 堆空间
修复应用程序中的线程泄漏。
增加操作系统级别的限制
ulimit -a
用户进程数增大?(-u) 1800
将进程迁移到不同的机器上
给机器增加更多内存
与其他 OOM 错误不同,这是由操作系统而非 JVM 触发的。
本机方法(native method)分配失败
打印的堆栈跟踪信息,最顶层的帧是本机方法
使用操作系统本地工具进行诊断
小编整理不易,对这份1200页Java架构面试专题及答案感兴趣劳烦帮忙转发/点赞一下,然后点击这里即可免费领取!