1.OutOfMemoryError

  • 抛出异常后先确定是堆溢出还是栈溢出
  1. 堆溢出:java.lang.OutOfMemoryError: Java heap space

    • 堆出现OOM(标志就是Java heap space)首先确认是内存溢出还是内存泄漏。常见的OOM就是堆溢出。
    • 内存泄漏: Memory Leak 申请到内存之后无法 释放 申请到的内存,造成这种情况的就是某个对象一直被引用这。
    • 内存溢出:Memory OverFlow :申请内存时没有足够的空间可以使用,抛出OOM。
    • 可以使用 Eclipse Memory Analyzer 或者 JProfiler(IDEA)分析内存是否泄漏
    1. -Xms 设置初始堆的大小,设置为20MB -Xms20m
    2. -Xmx设置最大堆的大小
  2. 虚拟机栈溢出和本地方法栈溢出

    1. HotSpot 虚拟机并不区分虚拟机栈和本地方法栈他两适合在一起的所以 用来设置本地方法栈大小的-Xoos并没有什么效果。
    2. -Xss 设置栈容量大小
    3. 栈可以抛出2种异常
      • StackOverflowError 线程请求的栈深度大于虚拟机所允许的最大深度。
      • OutOfMemoryError  扩展栈时无法申请到足够的内存,比较少见。
    4. 操作系统分配给每个进程的内存是有限的,如32位win给进程分配的是2G,栈内存 = 2GB - 堆Xmx - 方法区 MaxPermSize
    5. 线程越多分配的栈内存就越少,每个线程分配的栈容量就越大线程就越少,容易把剩下的内存耗尽。
    6. jvm默认情况下栈深度平均在1000-2000间(栈帧个数即方法数量),如果不能更换更高位数的操作系统也不能减少线程数量,那么可以通过减少堆的最大容量让出一部分内存来给栈,避免栈内存溢出。
  3. 方法区和运行时常量池溢出

    1. OutOfMemoryError:PermGen space 运行时常量池在方法区中他两都会抛出此异常。
    2. -XX:PermSize 方法区初始值大小
    3. -XX:MaxPermSize 方法区最大值
    4. 由于1.8 去永久带 而加入了 Metaspace 元空间 所以上面的配置 1.8 开始就不能失效了
    5. -XX:MetaspaceSize 元空间大小, -XX:MaxMetaspace元空间最大值。
  4. 本机直接内存溢出

    1. -XX: MaxDirectMemorySize 可以指定最大值,如果不指定默认和堆一样大。
    2. 由于直接内存不在堆里,它是供NIO使用的所以抛出OOM异常后通过jvm内存检测工具 在Heap Dump中没有明显错误,但是Dump文件很小就可以考虑直接内存溢出

知识点:

  1. string.intern()是一个本地方法,它只 返回字符串常量池中唯一的那个string。

            String st1 = new StringBuilder("Mi").append("bloom").toString(); // 初始字符串常量池不存在组合的Mibloom  ,但存在了Mi和bloom.
    String st2 = new StringBuilder("ja").append("va").toString();// 初始字符串常量池存在java
    System.out.println(st1.intern() == st1);// 1.6为 false,1.7为true
    System.out.println(st2.intern() == st2);//始终为false, 常量池中存在java,因此 st2.intern()返回的是常量池中的,而st2是堆中的。
    1. 只要代码中直接出现的字符串就还会被放入常量池,但是组合生成的字符串不会被放入常量池的,如常量池中有Mi和bloom,但是没有Mibloom。
    2. 如果字符串常量池中已经包含了一个等于此string对象的符号,则string.intern()返回字符串常量池中的对象。
    3. 如果字符串常量池中没有,则将string加入字符串常量池并返回字符串常量池中的对象,此加入操作在jdk1.6 和1.7 中有所不同。
      1. 1.6中首次出现的string加入字符串常量池中的是直接复制到永久代中的字符串常量池中,所以地址会发生变化。
      2. 1.7开始 首次出现的string加入字符串常量池是复制string的引用到常量池中,所以地址不会发生变化。1.7开始 字符串常量池被移到了堆中。
  2. JVM 其他配置参数
    //常见配置汇总
    //堆设置
    -Xms:初始堆大小
    -Xmx:最大堆大小
    -XX:NewSize=n:设置年轻代大小
    -XX:NewRatio=n:设置年轻代和年老代的比值.如:为3,表示年轻代与年老代比值为1:3,年轻代占整个年轻代年老代和的1/4
    -XX:SurvivorRatio=n:年轻代中Eden区与两个Survivor区的比值.注意Survivor区有两个.如:3,表示Eden:Survivor=3:2,一个Survivor区占整个年轻代的1/5
    -XX:MaxPermSize=n:设置持久代大小
    //收集器设置
    -XX:+UseSerialGC:设置串行收集器
    -XX:+UseParallelGC:设置并行收集器
    -XX:+UseParalledlOldGC:设置并行年老代收集器
    -XX:+UseConcMarkSweepGC:设置并发收集器
    //垃圾回收统计信息
    -XX:+PrintGC
    -XX:+PrintGCDetails
    -XX:+PrintGCTimeStamps
    -Xloggc:filename
    //并行收集器设置
    -XX:ParallelGCThreads=n:设置并行收集器收集时使用的CPU数.并行收集//线程数.
    -XX:MaxGCPauseMillis=n:设置并行收集最大暂停时间
    -XX:GCTimeRatio=n:设置垃圾回收时间占程序运行时间的百分比.公式为1/(1+n)
    //并发收集器设置
    -XX:+CMSIncrementalMode:设置为增量模式.适用于单CPU情况.
    -XX:ParallelGCThreads=n:设置并发收集器年轻代收集方式为并行收集时,使用的CPU数.并行收集线程数.

OOM异常 Java内存溢出的更多相关文章

  1. Java内存溢出异常(上)

    上一篇文章我们讲了JVM运行时数据区域与内存溢出异常,其中对于内存溢出异常这部分将的不够详细,这篇文章将着重讲解Java内存溢出异常的相关知识.如果有没看过上一篇文章的小伙伴们,请点击Java内存区域 ...

  2. Java内存溢出异常(下)

    此篇是上一篇文章Java内存溢出异常(上)的续篇,没有看过的同学,可以先看一下上篇.本篇文章将介绍剩余的两个溢出异常:方法区和运行时常量池溢出. 方法区和运行时常量池溢出 这部分为什么会放在一起呢?在 ...

  3. java内存溢出的解决思路

    原文地址:https://www.cnblogs.com/200911/p/3965108.html 内存溢出是指应用系统中存在无法回收的内存或使用的内存过多,最终使得程序运行要用到的内存大于虚拟机能 ...

  4. Java基础学习总结(30)——Java 内存溢出问题总结

    Java中OutOfMemoryError(内存溢出)的三种情况及解决办法 相信有一定java开发经验的人或多或少都会遇到OutOfMemoryError的问题,这个问题曾困扰了我很长时间,随着解决各 ...

  5. Java 内存溢出分析

    原文地址:Java 内存溢出分析 博客地址:http://www.moonxy.com 一.前言 Java 的 JVM 的内存一般可分为 3 个区:堆(heap).栈(stack)和方法区(metho ...

  6. 模拟Java内存溢出

    本文通过修改虚拟机启动参数,来剖析常见的java内存溢出异常(基于jdk1.8). 修改虚拟机启动参数Java堆溢出虚拟机栈溢出方法区溢出本机直接内存溢出 修改虚拟机启动参数   这里我们使用的是ID ...

  7. Java 内存溢出(java.lang.OutOfMemoryError)的常见情况和处理方式总结

    最近老是遇见服务器内存溢出的问题,故在网上搜了搜,总结了一些java内存溢出的解决方式 java.lang.OutOfMemoryError这个错误我相信大部分开发人员都有遇到过,产生该错误的原因大都 ...

  8. Java内存溢出详解

    转自:http://elf8848.iteye.com/blog/378805 一.常见的Java内存溢出有以下三种: 1. java.lang.OutOfMemoryError: Java heap ...

  9. Java内存溢出的详细解决方案

    本文介绍了Java内存溢出的详细解决方案.本文总结内存溢出主要有两种情况,而JVM经常调用垃圾回收器解决内存堆不足的问题,但是有时仍会有内存不足的错误.作者分析了JVM内存区域组成及JVM设置虚拟内存 ...

随机推荐

  1. Week3 Teamework from Z.XML-团队分工及贡献分分配办法

    引言:团队项目即将开展,本文将就团队分工,以及分数分配办法进行阐述 一.团队分工 本周我们团队进行了初步的分工,结果如下: PM: 李孟 Dev:毛宇 薛亚杰 肖俊鹏 罗凡 Test:周敏轩 马辰 李 ...

  2. [boost-2] 智能指针

    boost库学习: 智能指针: shared_ptr指针,定义在boost::shared_ptr,如果开发环境支持的话,可以使用memory中的std::shared_ptr. shared_ptr ...

  3. php获取微信token和ticket并返回签名

    jssdk.php页,主要获取token和ticket <?php /* * 微信公众号后台里获取appId和appSecret,并在公众号后台=>安全中心=>IP白名单中设置当前页 ...

  4. coredump分析

    首先通过命令 gdb freeswitch core.60954进入gdb. 这里freeswitch 是产生coredump的可执行应用,core.60954是应用产生的coredump文件. 然后 ...

  5. Configuring Dojo with dojoConfig - The Dojo Toolkit

    转载自Dojo官网 Configuring Dojo with dojoConfig The dojoConfig object (formerly djConfig) allows you to s ...

  6. (转)java中equals和等号(==)的区别浅谈

    java中的数据类型,可分为两类:1.基本数据类型,也称原始数据类型.byte,short,char,int,long,float,double,boolean   他们之间的比较,应用双等号(==) ...

  7. 解决hadoop 集群启动常见错误办法

    hadoop 集群常见错误解决办法 hadoop 集群常见错误解决办法: (一)启动Hadoop集群时易出现的错误: 1.   错误现象:Java.NET.NoRouteToHostException ...

  8. JDBC连接数据库的过程

    以连接MySQL为例: (1)加载MySQL数据库连接的驱动程序.到MySQL官网下载该驱动程序jar包,然后把包复制到WEB-INF/lib目录下,则JDBC会调用Class.forName()方法 ...

  9. 【BZOJ 2503】相框 图论+讨论

    这道题目就是考验了一下图论基本知识与对可爱的代码实现的应对能力. 我们先分析题干信息.我们要形成相框,那么所有的点的度为2(参与的点),那么所有度大于2的点都需要熔断,而且一次完成所有关于这个点的熔断 ...

  10. How to reclaim space in InnoDB when innodb_file_per_table is ON

    When innodb_file_per_table is OFF and all data is going to be stored in ibdata files. If you drop so ...