JVM性能优化 (一) 初识JVM (3)

jvm的内存模型在1.7和1.8有较大的区别,虽然本文中是以1.8为例进行讲解,但是我们也会对1.7的内存模型有所了解。所以我们先来了解一下1.7在学习1.8的内存模型

3.1、jdk1.7的堆内存模型

JVM性能优化 (一) 初识JVM

Young 年轻区(代)
Young区域被划分为三部分,Eden区和两个大小严格相同的Survivor区,其中,Survivor区间中,某一时刻只有其中一个是被使用的,另外一个留做垃圾收集时复制对象用,在Eden区间变满的时候,GC就会将存活的对象移到空闲的Survivor区间中,根据JVM的策略,在经过几次垃圾收集后,任然存活于Survivor的对象被移动到Tenured区间。

Tenured 年老区
Tenured 区主要保存生命周期长的对象,一般是一些老的对象,当一些对象在Young复制转移一定的次数以后,对象就会被转移到Tenured区,一般如果系统中用了application级别的缓存,缓存中的对象往往会被转移到这一区间

Perm 永久区
Perm代主要保存 class、method、filed对象,这部分的空间一般不会溢出,除非一次性加载了很多的类,不过在设计到热部署的应用服务器的时候,有时候会遇到 java.lang.OutOfMempryError:PermGen Space的错误,造成这个错误的很大原因就有可能是每次都重新部署,但是重新部署后,类的class没有被卸载掉,这样就造成了大量的class对象保存在perm中,这种情况下,一般重新启动应用服务器可以解决问题

Virtual区
最大内存和初始内存的差值,就是 Virtual区

3.2、jdk1.8的堆内存模型

述

由上图可以看出,jdk1.8的内存模型是 由2部分组成,年轻代 + 年老代
年轻代:Eden + 2*Survivor
年老代:OldGen
在jdk1.8中变化最大的Perm区,用Metaspace(元数据空间)进行了替换
需要特别说明的是:Metaspace所占用的内存空间不是在虚拟机内部,而是在本地内存空间中,这也是与1.7的永久代最大的区别所在

JVM性能优化 (一) 初识JVM

3.3、为什么要废弃1.7中的永久区?

关于为什么会废弃1.7中的永久区 ,我们在官网中可以看到说明,官网地址:

This is part of the JRockit and Hotspot convergence effort. JRockit customers do not need to configure the permanent generation (since JRockit does not have a permanent generation) and are accustomed to not configuring the permanent generation.

移除用永久代是为融合Hot Spot JVm与JRockit VM 而做出的努力,因为Jrockit没有永久代,不需要配置永久代

在我们现实使用中,由于永久代内存经常不够用或发生内存泄露,报出异常 java.lang.OutOfMempryError:PermGen ,因此将永久区废弃,而改用元空间,改为了使用本地内存空间

3.4、通过jstat命令进行查看 堆内存使用情况

jstat 命令可以查看堆内存各部分的使用量,以及加载类的数量,命令的格式如下:
jstat [-命令选项] [vmid] [间隔时间/毫秒] [查询次数]

3.4.1 查看class加载统计
[root@localhost ~]# jstat -class 20736

JVM性能优化 (一) 初识JVM


说明:

方法 描述
Loaded   加载class的数量  
Bytes   所占用空间大小  
Unloaded   未加载数量  
Bytes   未加载占用空间  
Time   时间  

3.4.2 查看编译统计

[root@localhost ~]# jstat -compiler 20736

方法 描述
Compiled   编译数量  
Failed   失败数量  
Invalid   不可用数量  
Time   时间  
FailedType   失败类型  
FailedMethod   失败的方法  

3.4.3 垃圾回收统计
[root@localhost ~]# jstat -gc 20736


S0C:第一个Survivor区的大小(KB)
S1C:第二个Survivor区的大小(KB)
S0U:第一个Survivor区的使用大小(KB)
S1U:第二个Survivor区的使用大小(KB)
EC:Eden区的大小(KB)
EU:Eden区的使用大小(KB)
OC:Old区大小(KB)
OU:Old区使用大小(KB)
MC:方法区大小(KB)
MU:方法区使用大小(KB)
CCSC:压缩类空间大小(KB)
CCSU:压缩类空间使用大小(KB)
YGC:年轻代垃圾回收次数
YGCT:年轻代垃圾回收消耗时间
FGC:老年代垃圾回收次数
FGCT:老年代垃圾回收消耗时间
GCT :垃圾回收消耗总时间

四、总结

到这里文章就讲完了,有疑问的兄弟可以在下面讨论或留言,也祝大家在今年开开心心,健健康康,能够拥有一份好工作,大家加油,我是牧小农!

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wsswjy.html