jdk1.8--JVM分析与调优

本文详细介绍了JDK1.8中JVM的变化,包括元空间代替永久代,GC过程,以及JVM参数配置。强调了元空间不再受限于-XX:MaxPermSize,而是由本地内存决定,解决了之前可能出现的OOM问题。并提供了新生代、老年代的GC算法解析,以及JVM参数配置的建议,如根据老年代存活对象大小来设定MetaspaceSize和堆内存大小。
摘要由CSDN通过智能技术生成

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的问题——如运行时使用反射、代理等。

干货:可以发现最明显的一个变化是元空间从虚拟机转移到了本地内存。默认情况下,元数据空间大小仅受限于本地内存,<

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值