⭐⭐⭐ Spring Boot 项目实战 ⭐⭐⭐ Spring Cloud 项目实战
《Dubbo 实现原理与源码解析 —— 精品合集》 《Netty 实现原理与源码解析 —— 精品合集》
《Spring 实现原理与源码解析 —— 精品合集》 《MyBatis 实现原理与源码解析 —— 精品合集》
《Spring MVC 实现原理与源码解析 —— 精品合集》 《数据库实体设计合集》
《Spring Boot 实现原理与源码解析 —— 精品合集》 《Java 面试题 + Java 学习指南》

摘要: 原创出处 http://www.importnew.com/author/tangyouhua 「唐尤华」欢迎转载,保留摘要,谢谢!


🙂🙂🙂关注**微信公众号:【芋道源码】**有福利:

  1. RocketMQ / MyCAT / Sharding-JDBC 所有源码分析文章列表
  2. RocketMQ / MyCAT / Sharding-JDBC 中文注释源码 GitHub 地址
  3. 您对于源码的疑问每条留言将得到认真回复。甚至不知道如何读源码也可以请教噢
  4. 新的源码解析文章实时收到通知。每周更新一篇左右
  5. 认真的源码交流微信群。

1. Java 堆空间

发生频率:5颗星

造成原因

  • 无法在 Java 堆中分配对象

  • 吞吐量增加

  • 应用程序无意中保存了对象引用,对象无法被 GC 回收

  • 应用程序过度使用 finalizer。finalizer 对象不能被 GC 立刻回收。finalizer 由结束队列服务的守护线程调用,有时 finalizer 线程的处理能力无法跟上结束队列的增长

解决方案

  • 使用 -Xmx 增加堆大小
  • 修复应用程序中的内存泄漏

2. GC 开销超过限制

发生频率:5颗星

造成原因

  • Java 进程98%的时间在进行垃圾回收,恢复了不到2%的堆空间,最后连续5个(编译时常量)垃圾回收一直如此。

解决方案

  • 使用 -Xmx 增加堆大小
  • 使用 -XX:-UseGCOverheadLimit 取消 GC 开销限制
  • 修复应用程序中的内存泄漏

3. 请求的数组大小超过虚拟机限制

发生频率:2颗星

造成原因

  • 应用程序试图分配一个超过堆大小的数组

解决方案

  • 使用 -Xmx 增加堆大小
  • 修复应用程序中分配巨大数组的 bug

4. Perm gen 空间

发生频率:3颗星

造成原因

Perm gen 空间包含:

  • 类的名字、字段、方法
  • 与类相关的对象数组和类型数组
  • JIT 编译器优化

当 Perm gen 空间用尽时,将抛出异常。

解决方案

  • 使用 -XX: MaxPermSize 增加 Permgen 大小
  • 不重启应用部署应用程序可能会导致此问题。重启 JVM 解决

5. Metaspace

发生频率:3颗星

造成原因

  • 从 Java 8 开始 Perm gen 改成了 Metaspace,在本机内存中分配 class 元数据(称为 metaspace)。如果 metaspace 耗尽,则抛出异常

解决方案

  • 通过命令行设置 -XX: MaxMetaSpaceSize 增加 metaspace 大小
  • 取消 -XX: maxmetsspacedize
  • 减小 Java 堆大小,为 MetaSpace 提供更多的可用空间
  • 为服务器分配更多的内存
  • 可能是应用程序 bug,修复 bug

6. 无法新建本机线程

发生频率:5颗星

造成原因

  • 内存不足,无法创建新线程。由于线程在本机内存中创建,报告这个错误表明本机内存空间不足

解决方案

  • 为机器分配更多的内存
  • 减少 Java 堆空间
  • 修复应用程序中的线程泄漏。
  • 增加操作系统级别的限制
    • ulimit -a
    • 用户进程数增大 (-u) 1800
  • 使用 -Xss 减小线程堆栈大小

7. 杀死进程或子进程

发生频率:1颗星

造成原因

  • 内核任务:内存不足结束器,在可用内存极低的情况下会杀死进程

解决方案

  • 将进程迁移到不同的机器上
  • 给机器增加更多内存

与其他 OOM 错误不同,这是由操作系统而非 JVM 触发的。

8. 发生 stack_trace_with_native_method

发生频率:1颗星

造成原因

  • 本机方法(native method)分配失败
  • 打印的堆栈跟踪信息,最顶层的帧是本机方法

解决方案

  • 使用操作系统本地工具进行诊断
文章目录
  1. 1. 1. Java 堆空间
    1. 1.1. 发生频率:5颗星
    2. 1.2. 造成原因
    3. 1.3. 解决方案
  2. 2. 2. GC 开销超过限制
    1. 2.1. 发生频率:5颗星
    2. 2.2. 造成原因
    3. 2.3. 解决方案
  3. 3. 3. 请求的数组大小超过虚拟机限制
  4. 4. 发生频率:2颗星
    1. 4.1. 造成原因
    2. 4.2. 解决方案
  5. 5. 4. Perm gen 空间
    1. 5.1. 发生频率:3颗星
    2. 5.2. 造成原因
    3. 5.3. 解决方案
  6. 6. 5. Metaspace
    1. 6.1. 发生频率:3颗星
    2. 6.2. 造成原因
    3. 6.3. 解决方案
  7. 7. 6. 无法新建本机线程
    1. 7.1. 发生频率:5颗星
    2. 7.2. 造成原因
    3. 7.3. 解决方案
  8. 8. 7. 杀死进程或子进程
    1. 8.1. 发生频率:1颗星
    2. 8.2. 造成原因
    3. 8.3. 解决方案
  9. 9. 8. 发生 stack_trace_with_native_method
    1. 9.1. 发生频率:1颗星
    2. 9.2. 造成原因
    3. 9.3. 解决方案