• OOM解决方案


    一、什么是OOM

      OutOfMemory(内存溢出)就是内存用完了,意思就是说,当JVM因为没有足够的内存来为对象分配空间并且垃圾回收器也已经没有空间可回收时,就会抛出这个error(注:非exception,因为这个问题已经严重到不足以被应用处理)。

    PS.一个线程OOM,进程里其他线程还能运行吗?一个线程溢出后,进程里的其他线程还能照常运行,当一个线程抛出OOM异常后,它所占据的内存资源会全部被释放掉,从而不会影响其他线程的运行。

     

    二、OOM产生原因

    1. 分配的少了:比如虚拟机本身可使用的内存(一般通过启动时的VM参数指定)太少。
    2. 应用用的太多,并且用完没释放,浪费了。此时就会造成内存泄露或者内存溢出。
     三、OOM类型

      1.永久区溢出 :java.lang.OutOfMemoryError: PermGen space

              这一部分用于存放Class和Meta的信息,Class在被 Load的时候被放入PermGen space区域(包括常量池: 静态变量),它和存放Instance的Heap区域不同,GC(Garbage Collection)不会在主程序运行期对PermGen space进行清理,所以如果你的APP会LOAD很多CLASS的话,就很可能出现PermGen space错误。这种错误常见在web服务器对JSP进行pre compile的时候。可以通过设置jvm启动参数来解决:
    -XX:MaxPermSize=256m
    

      2. 堆溢出 java.lang.OutOfMemoryError: Java heap space

      这部分用于存放类的实例。被缓存的实例(Cache)对象,大的map,list引用大的对象等等,都会保存于此,过期引用可能会导致堆溢出。堆内存会在jvm启动时自动设置,初始值 -Xms为物理内存的1/64,最大值-Xmx为1/4;可以通过参数-Xmn、-Xms、-Xmx设置,一般-Xms和-Xmx不超过80%,-Xmn为-Xmx的1/4;

      3.栈溢出: Exception in thread "main" java.lang.StackOverflowError

      这部分用于存放局部变量、方法栈帧信息。递归太深,栈帧太多,也就是函数调用层级过多时就会出现此异常,检查是否有死递归的情况。对应的启动参数为:-Xss ( JDK1.5以后默认是1M,之前是256K)

    四、OOM排查

      碰到OOM之后,想办法拿到heap dump,分析之。

    -XX:+HeapDumpOnOutOfMemoryError #程序运行配置,自动生成
    jmap -dump:live,format=b,file=<filepath> <pid>  
    

      可以通过可视化软件MAT或JvisualVM查看dump文件,查找class或者大对象的引用,追溯代码。

    五、OOM问题解决

      概率:%50 修改程序  40%环境配置  10%内存

  • 相关阅读:
    CAS实战の自定义注销
    CAS实战の自定义登录
    MongoDB学习总结
    Django登录使用的技术和组件
    Docker搭建Hadoop环境
    配置Nginx的坑及思路
    Centos7 升级 sqlite3
    Python基础题
    pandas的数据筛选之isin和str.contains函数
    CentOS7 下Docker最新入门教程 超级详细 (安装以及简单的使用)
  • 原文地址:https://www.cnblogs.com/qmillet/p/12984804.html
Copyright © 2020-2023  润新知