JVM的优化及JVM的内存模型
一、JVM优化
为什么做优化:程序卡住,CPU负载突然升高,
二、JVM的运行参数
、三种参数类型
标准参数
-help
-version
(jvm的标准参数,一般都是很稳定的,在未来的JVM版本中不会改变,可以使用java -help 检索出所有的标准参数)
-X参数 (非标准参数)
-Xint
-Xcomp
(jvm的-X参数是非标准参数,在不同版本的jvm中,参数可能会有所不同,可以通过java X查看非标准参数)
-XX参数(使用率较高)
-XX:newSize
-XX:+UseSerialGC
(-XX参数也是非标准参数,主要用于jvm的调优和debug操作。
-XX参数的使用有2种方式,一种是boolean类型,一种是非boolean类型)
三、JVM的内存模型
JDK1.7堆内存模型
Young 年轻区(代) Young区被划分为三部分,Eden区和两个大小严格相同的Survivor区,其中, Survivor区间中,某一时刻只有其中一个是被使用的,另外一个留做垃圾收集时复制 对象用,在Eden区间变满的时候, GC就会将存活的对象移到空闲的Survivor区间 中,根据JVM的策略,在经过几次垃圾收集后,任然存活于Survivor的对象将被移动 到Tenured区间。
Tenured 年老区 Tenured区主要保存生命周期长的对象,一般是一些老的对象,当一些对象在Young 复制转移一定的次数以后,对象就会被转移到Tenured区,一般如果系统中用了 application级别的缓存,缓存中的对象往往会被转移到这一区间。
Perm 永久区 Perm代主要保存class,method,filed对象,这部份的空间一般不会溢出,除非一次性 加载了很多的类,不过在涉及到热部署的应用服务器的时候,有时候会遇到 java.lang.OutOfMemoryError : PermGen space 的错误,造成这个错误的很大原因 就有可能是每次都重新部署,但是重新部署后,类的class没有被卸载掉,这样就造 成了大量的class对象保存在了perm中,这种情况下,一般重新启动应用服务器可以 解决问题。 Virtual区: 大内存和初始内存的差值,就是Virtual区。
jdk1.8的堆内存模型
jdk1.8的内存模型是由2部分组成,年轻代 + 年老代。
年轻代:Eden + 2*Survivor
年老代:OldGen
JDK1.7与JDK1.8的堆内存区别
在jdk1.8中变化大的Perm区,用Metaspace(元数据空间)进行了替换。
Metaspace所占用的内存空间不是在虚拟机内部,而是在本地内存 空间中
jdk1.7中的永久区删除
删除JDK1.7永久区的原因:
现实使用中,由于永久代内存经常不够用或发生内存泄露,爆出异常 java.lang.OutOfMemoryError: PermGen。
基于此,将永久区废弃,而改用元空间,改为了使用本地内存空间。