java八股文面试[JVM]——什么情况下会抛出OOM

什么情况下,会抛出OOM呢?
  • JVM98%的时间都花费在内存回收

  • 每次回收的内存小于2%

满足这两个条件将触发OutOfMemoryException ,这将会留给系统一个微小的间隙 以做一些Down之前的操作,比如手动打印Heap Dump。并不是内存被耗空的时候才抛出

主要原因有三类:

一,业务需要比较多的内存,但是jvm分配的太少;

二,GC回收内存的速度赶不上程序运行消耗内存的速度。

三,存在内存泄漏情况,比如打开文件不释放、创建网络连接不关闭、不再使用的对象未断开引用关系、使用静态变量持有大对象引用等等,久而久之也会造成OOM。

区域:

发生oom的区域主要在哪里呢?

可以这么说,除了程序计数器以外,其他区域都有可能 。比如直接内存,元空间、本地方法栈、虚拟机栈、堆外等等。

系统OOM之前都有哪些现象?
  • 每次垃圾回收的时间越来越长,由之前的10ms延长到50ms左右,FullGC的时间也有之前的0.5s延长到4、5s

  • FullGC的次数越来越多,最频繁时隔不到1分钟就进行一次FullGC

  • 老年代的内存越来越大并且每次FullGC后,老年代只有少量的内存被释放掉

如何进行堆Dump文件分析?

可以通过指定启动参数 -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/usr/app/data/dump/heapdump.hpro 在发生OOM的时候自动导出Dump文件

如何进行GC日志分析?

为了方便分析GC日志信息,可以指定启动参数 【-Xloggc : app-gc.log -XX:+PrintGCDetails -XX:+PrintGCDateStamps】,方便详细地查看GC日志信息

  1. 使用 【jinfopid】查看当前JVM堆的相关参数

  2. 继续使用 【jstat-gcutil 2315 1s 10】查看10s内当前堆的占用情况

  3. 也可以使用【jmap-heap pid】查看当前JVM堆的情况

  4. 我们可以继续使用 【jmap-F -histo pid | head -n 20】,查看前20行打印,即查看当前top20的大对象,一般从这里可以发现一些异常的大对象,如果没有,那么可以继续排名前50的大对象,分析

  5. 最后使用【jmap -F -dump:file=a.bin pid】,如果dump文件很大,可以压缩一下【tar -czvf a.tar.gz a.bin】

  6. 再之后,就是对dump文件进行分析了,使用MAT分析内存泄露

内存溢出的原因有哪些,如何排查线上问题?
  1. java.lang.OutOfMemoryError: ......java heap space..... 堆栈溢出,代码问题 的可能性极大

  2. java.lang.OutOfMemoryError: GC over head limit exceeded 系统处于高频的GC状态 ,而且回收的效果依然不佳的情况,就会开始报这个错误,这种情况一般是产生了很多不可以被释放的对象,有可能是引用使用不当 导致,或申请大对象 导致,但是java heap space的内存溢出有可能提前不会报这个错误,也就是可能内存就直接不够 导致,而不是高频GC.

  3. java.lang.OutOfMemoryError: PermGen space jdk1.7之前才会出现的问题 ,原因是系统的代码非常多或引用的第三方包 非常多、或代码中使用了大量的常量、或通过intern注入常量、或者通过动态代码加载等方法,导致常量池 的膨胀

  4. java.lang.OutOfMemoryError: Direct buffer memory 直接内存不足 ,因为jvm垃圾回收不会回收掉直接内存这部分的内存 ,所以可能原因是直接或间接使用了ByteBuffer 中的allocateDirect方法的时候,而没有做clear

  5. java.lang.Stack OverflowError - Xss设置的太小了

  6. java.lang.OutOfMemoryError: unable to create new native thread 堆外内存 不足,无法为线程 分配内存区域

  7. java.lang.OutOfMemoryError: request {} byte for {}out of swap 地址空间不够

知识来源:

马士兵教育

什么是oom(Out Of Memory)? - 知乎

相关推荐
冷琴19961 分钟前
基于java+springboot的酒店预定网站、酒店客房管理系统
java·开发语言·spring boot
daiyang123...28 分钟前
IT 行业的就业情况
java
爬山算法1 小时前
Maven(6)如何使用Maven进行项目构建?
java·maven
.生产的驴1 小时前
Electron Vue框架环境搭建 Vue3环境搭建
java·前端·vue.js·spring boot·后端·electron·ecmascript
爱学的小涛1 小时前
【NIO基础】基于 NIO 中的组件实现对文件的操作(文件编程),FileChannel 详解
java·开发语言·笔记·后端·nio
吹老师个人app编程教学1 小时前
详解Java中的BIO、NIO、AIO
java·开发语言·nio
爱学的小涛1 小时前
【NIO基础】NIO(非阻塞 I/O)和 IO(传统 I/O)的区别,以及 NIO 的三大组件详解
java·开发语言·笔记·后端·nio
北极无雪1 小时前
Spring源码学习:SpringMVC(4)DispatcherServlet请求入口分析
java·开发语言·后端·学习·spring
琴智冰1 小时前
SpringBoot
java·数据库·spring boot