JVM总结4-内存溢出相关的异常
2017-03-10 00:00
253 查看
1 年老代堆空间被占满
异常: java.lang.OutOfMemoryError: Java heap space说明:
这是最典型的内存泄漏方式,简单说就是所有堆空间都被无法回收的垃圾对象占满,虚拟机无法再在分配新空间。
如上图所示,这是非常典型的内存泄漏的垃圾回收情况图。所有峰值部分都是一次垃圾回收点,所有谷底部分表示是一次垃圾回收后剩余的内存。连接所有谷底的点,可以发现一条由底到高的线,这说明,随时间的推移,系统的堆空间被不断占满,最终会占满整个堆空间。因此可以初步认为系统内部可能有内存泄漏。(上面的图仅供示例,在实际情况下收集数据的时间需要更长,比如几个小时或者几天)
解决:
这种方式解决起来也比较容易,一般就是根据垃圾回收前后情况对比,同时根据对象引用情况(常见的集合对象引用)分析,基本都可以找到泄漏点。
2 持久代被占满
异常:java.lang.OutOfMemoryError: PermGen space说明:
Perm空间被占满。无法为新的class分配存储空间而引发的异常。这个异常以前是没有的,但是在Java反射大量使用的今天这个异常比较常见了。主要原因就是大量动态反射生成的类不断被加载,最终导致Perm区被占满。
更可怕的是,不同的classLoader即便使用了相同的类,但是都会对其进行加载,相当于同一个东西,如果有N个classLoader那么他将会被加载N次。因此,某些情况下,这个问题基本视为无解。当然,存在大量classLoader和大量反射类的情况其实也不多。
解决:
1. -XX:MaxPermSize=16m
2. 换用JDK。比如JRocket。
3 堆栈溢出
异常:java.lang.StackOverflowError说明:这个就不多说了,一般就是递归没返回,或者循环调用造成
4 线程堆栈满
异常:Fatal: Stack size too small说明:java中一个线程的空间大小是有限制的。JDK5.0以后这个值是1M。与这个线程相关的数据将会保存在其中。但是当线程空间满了以后,将会出现上面异常。
解决:增加线程栈大小。-Xss2m。但这个配置无法解决根本问题,还要看代码部分是否有造成泄漏的部分。
5 系统内存被占满
异常:java.lang.OutOfMemoryError: unable to create new native thread说明:
这个异常是由于操作系统没有足够的资源来产生这个线程造成的。系统创建线程时,除了要在Java堆中分配内存外,操作系统本身也需要分配资源来创建线程。因此,当线程数量大到一定程度以后,堆中或许还有空间,但是操作系统分配不出资源来了,就出现这个异常了。
分配给Java虚拟机的内存愈多,系统剩余的资源就越少,因此,当系统内存固定时,分配给Java虚拟机的内存越多,那么,系统总共能够产生的线程也就越少,两者成反比的关系。同时,可以通过修改-Xss来减少分配给单个线程的空间,也可以增加系统总共内生产的线程数。
解决:
1. 重新设计系统减少线程数量。
2. 线程数量不能减少的情况下,通过-Xss减小单个线程大小。以便能生产更多的线程。
参考资料:http://pengjiaheng.iteye.com/blog/552456
相关文章推荐
- JVM内存及内存溢出异常(个人总结)
- jvm内存相关的知识总结
- JVM - 内存溢出问题排查相关命令jcmd jmap
- JAVA内存区域及内存溢出异常——总结
- JVM异常之:直接内存溢出
- JVM相关学习记录与总结(内存&GC&类加载&工具)
- [置顶] 《深入理解Java虚拟机》——Java内存区域与内存溢出异常学习总结
- (JVM1)Java内存区域与内存溢出异常之二
- JVM 学习笔记1 JAVA内存区域与溢出异常
- JVM内核学习 --内存相关,内存结构, GC,ClassLoader,内存溢出
- Java基础--jvm(内存区域与内存溢出异常--运行时数据区域)
- JVM内存及内存溢出异常(个人总结)
- JVM学习小记01--内存区域以及内存溢出异常
- jvm常见内存溢出异常
- 深入理解Java虚拟机JVM高级特性与最佳实践阅读总结——第二章 Java内存区域与内存溢出异常
- 【总结】性能调优:JVM内存调优相关文章
- 深入理解Java虚拟机笔记--JVM内存模型及溢出问题总结
- JVM内存溢出问题总结
- JVM----内存区域及溢出异常
- 第2章 Java内存区域与内存溢出异常--《深入理解 Java 虚拟机》笔记