JVM调优分析
1.JVM系统级的调优
Full GC: 会对整个堆进行整理,包括Young、Tenured和Perm。Full GC因为需要对整个堆进行回收,所以比较慢,因此应该尽可能减少Full GC的次数。
导致Full GC的原因:
1.年老代(Tenured)被写满: 调优时尽量让对象在新生代GC时被回收、让对象在新生代多存活一段时间和不要创建过大的对象及数组避免直接在旧生代创建对象 。
2.持久代Pemanet Generation空间不足: 增大Perm Gen空间,避免太多静态对象 , 控制好新生代和旧生代的比例
3.System.gc()被调用: 垃圾回收不要手动触发,尽量依靠JVM自身的机制
2.JVM调优参数参考
1.针对JVM堆的设置,一般可以通过-Xms -Xmx限定其最小、最大值,为了防止垃圾收集器在最小、最大之间收缩堆而产生额外的时间,通常把最大、最小设置为相同的值;
2.年轻代和年老代将根据默认的比例(1:2)分配堆内存, 可以通过调整二者之间的比率NewRadio来调整二者之间的大小,也可以针对回收代。比如年轻代,通过 -XX:newSize -XX:MaxNewSize来设置其绝对大小。同样,为了防止年轻代的堆收缩,我们通常会把-XX:newSize -XX:MaxNewSize设置为同样大小。
3.年轻代和年老代设置大小带来的影响:
1)更大的年轻代必然导致更小的年老代,大的年轻代会延长普通GC的周期,但会增加每次GC的时间;小的年老代会导致更频繁的Full GC
2)更小的年轻代必然导致更大年老代,小的年轻代会导致普通GC很频繁,但每次的GC时间会更短;大的年老代会减少Full GC的频率
注意: 如果应用存在大量的临时对象,应该选择更大的年轻代;如果存在相对较多的持久对象,年老代应该适当增大。但很多应用都没有这样明显的特性。
建议:
1)本着Full GC尽量少的原则,让年老代尽量缓存常用对象,JVM的默认比例1:2也是这个道理 。
2)通过观察应用一段时间,看其他在峰值时年老代会占多少内存,在不影响Full GC的前提下,根据实际情况加大年轻代,比如可以把比例控制在1:1。但应该给年老代至少预留1/3的增长空间。
3.调优分析和建议
1.配置JVM日志参数,通过结果分析调优:
-Xloggc:E:/test/log --日志文件路径
-XX:+PrintGCDetails --打印GC信息
2.配置建议:
1.将java堆的初始值-Xms和最大值-Xmx设置为老年代活跃数据大小的3~4倍
2.永久带的初始值-XX:PermSize及最大值-XX:MaxPermSize应该比永久代活跃数据大1.2~1.5倍
3.新生代空间应该为老年代空间活跃数据的1~1.5倍
参考: 如果java堆的初始值及最大值为活跃数据的3~4倍,新生代为活跃数据的1~1.5倍时,老年代应设置为活跃数据大小的2~3倍
1.减少MinorGc消耗时间:
1.老年代空间大小不应该小于活跃数据大小的1.5倍
2.新生代空间至少应为Java堆的10%,,通过-Xmx和-Xms可以设定该值。
3.增大Java堆大小时,需要注意不要超过JVM可用的物理内存数。
注:以上内容仅供个人学习记录使用,如有问题,请慎用!