jdk1.8—JVM分析与调优
2019年01月29日 01:13:30 small_J_J 阅读数 632
原文:jdk1.8——jvm分析与调优 - 简书
作者:蓝山牧童
很多文章都是讲如何配置JVM各个参数的,但是真正生产环境中,各个参数的值应该按什么套路配,却鲜有提及。
本文分四个部分,分别是JVM说明,GC的过程、参数配置和具体配置值。
一、JVM空间说明
在JDK1.7及以前,HotSpot虚拟机将java类信息、常量池、静态变量、即时编译器编译后的代码等数据,存储在Perm(永久带)里(对于其他虚拟机如BEA JRockit、IBM J9等是不存在永久带概念的),类的元数据和静态变量在类加载的时候被分配到Perm里,当常量池回收或者类被卸载的时候,垃圾收集器会回收这一部分内存,但效果不太理想。
JDK1.8时,HotSpot虚拟机对JVM模型进行了改造,将类元数据放到了本地内存中,将常量池和静态变量放到了Java堆里,HotSpot VM将会为类的元数据明确的分配与释放本地内存,
在这种架构下,类元数据就突破了-XX:MaxPermSize的限制,所以此配置已经失效,现在可以使用更多的本地内存。这样一定程度上解决了原来在运行时生成大量的类,从而经常Full GC的问题——如运行时使用反射、代理等。
堆
干货:可以发现最明显的一个变化是元空间从虚拟机转移到了本地内存。默认情况下,元数据空间大小仅受限于本地内存,<