本博客为炼数成金JVM教程第八课
目录
- 内存溢出(OOM)的原因
- MAT使用基础
- 浅堆(shallow Heap) 和 深堆(Retained Heap)
- 显示入引用(incoming) 和出引用(outgoing)
- 支配树
- 使用Visual VM 分析堆
Tomcat OOM分析案例
JVM中,有哪些内存区间?
永久区不属于堆,但属于JVM进程的空间。
线程栈:是操作系统分配给JVM的一块内存区域。虽然不在堆里面,但是这几块空间加起来不能超过操作系统可以分配给JVM的内存空间。
这四块内存空间的任意一块不满足内存要求,都会导致内存溢出。
堆溢出
public static void main(String args[]){
ArrayList<byte[]> list=new ArrayList<byte[]>();
for(int i=0;i<1024;i++){
list.add(new byte[1024*1024]);
}
}
占用大量堆空间,直接溢出
Exception in thread "main" java.lang.OutOfMemoryError: **Java heap space**
at geym.jvm.ch8.oom.SimpleHeapOOM.main(SimpleHeapOOM.java:14)
解决方案:
1: 增加堆空间
2:及时释放内存
永久区溢出
由于类的原信息保存在永久区,我们生成大量的类,导致永久区溢出
public static void main(String[] args) {
for(int i=0;i<100000;i++){
CglibBean bean = new CglibBean("geym.jvm.ch3.perm.bean"+i,new HashMap());
}
}
Caused by: java.lang.OutOfMemoryError: **PermGen space**
[Full GC[Tenured: 2523K->2523K(10944K), 0.0125610 secs] 2523K->2523K(15936K),
[Perm : 4095K->4095K(4096K)], 0.0125868 secs] [Times: user=0.02 sys=0.00, real=0.01 secs]
Heap
def new generation