jdk8 调优

一、堆内存模型

1.1 堆内存划分:

  • New(年轻代)

             年轻代分为:Eden,Survivor0,Survivor1,s0和s1一般情况下大小是相等的。

  • Old(年老代)
  • Perm(永久代),1.8以后叫metaspace(元空间)

1.2 GC

GC分为两种:Minor GC(young GC) , FullGC。

GC流程:

1、新创建的对象会首先在Eden区。

2、当Eden区满了后,进行第一次Minor GC,存活的对象会被复制到s0区。Eden被清空。

3、新对象又被创建,放到Eden。Eden区满了后,对Eden和s0进行第二次Minor GC,存活的对象会被复制到s1区,Eden和s0被清空。

4、当一个对象被Minor GC的次数达到15(对象年龄,可配置)时,就会被移到Old区。有种情况比较特别,如果对象大小超过s0的一半时,即使没到年龄也会被直接回收到Old区。

5、当Old区满了的时候就会进行一次FullGC。

6、后面的流程继续回到步骤1,进行循环。

FullGC过程中会发生STW(Stop The World)服务暂停,导致tomcat无法对外提供服务。

二、垃圾收集算法

1、标记-清除

2、复制

3、标记整理

4、分代收集

 

三、收集器类型

1、其他旧版本的收集器

2、CMS

CMS(Concurrent Mark Sweep)收集器是一种以获取最短回收停顿时间为目标的收集器。目前很大一部分的Java应用都集中在互联网站或B/S系统的服务端上,这类应用尤其重视服务的响应速度,希望系统停顿时间最短,以给用户带来较好的体验。

从名字(包含“Mark Sweep”)上就可以看出CMS收集器是基于“标记-清除”算法实现的,它的运作过程相对于前面几种收集器来说要更复杂一些,整个过程分为4个步骤,包括:

  • 初始标记
  • 并发标记
  • 重新标记
  • 并发清除

优点: 并发收集、低停顿

缺点:产生大量空间碎片、并发阶段会降低吞吐量

3、G1

G1是目前技术发展的最前沿成果之一,HotSpot开发团队赋予它的使命是未来可以替换掉JDK1.5中发布的CMS收集器。

优点:

  • 空间整合,不会产生内存空间碎片。
  • 可预测停顿。

4、ZGC

jdk11中的收集器。

三、调优目的

尽可能让对象在Eden,s0,s1区域来回复制过程中被回收,而不是最后跑到了年老代停留,最后触发FullGC。

当发生发生多次Minor GC 后,如果年老代内存占用没有增加,说明调优配置是比较恰当的。

四、调优实践

4.1、工具

jvisualvm

 

4.2、实时数据

1、jstat -gc 13221 1000 ,每1秒查看线程号13221的堆内存各分区分配和使用空间,Minor GC从2544到2547.

2、jstat -gcutil pid 1000,对内存的分配和使用比例 ,Minor GC从2512到2514,一次耗时20毫秒。

 

 

4.3、推荐配置

 

jdk1.8以上版本,使用G1:

-Xms8096M -Xmx8096M -Xmn3072M -XX:SurvivorRatio=4 -XX:MetaspaceSize=512M -XX:MaxMetaspaceSize=512M -XX:+UseParNewGC -XX:+UseG1GC 

Xmn 为 Xmx的3/8。

  • Java堆 :
    • -Xms 初始堆大小
    • -Xmx 最大堆大小
    • -Xmn年轻代大小
    • -XX:NewSize 初始新生代大小
    • -XX:MaxNewSize 最大新生代大小

       注意:-Xmn,-XX:NewSize/-XX:MaxNewSize同时设置时,

        高优先级:-XX:NewSize/-XX:MaxNewSize 
       中优先级:-Xmn(默认等效 -Xmn=-XX:NewSize=-XX:MaxNewSize=?) 
       低优先级:-XX:NewRatio 
       推荐使用-Xmn参数配置

  • Java栈 : -Xss 每个线程栈的大小,jdk5后是1m,系统通常是3000-5000个线程
  • -XX:MetaspaceSize 元空间大小,默认是系统内存,所以最好限制下
    -XX:MaxMetaspaceSize 最大元空间大小

 

 

切换到G1 GC算法

G1 GC已成为自Java 9以来的默认GC算法,您可以安全地考虑将应用程序移至此算法。与Concurrent Mark Sweep相比,它可以提供更好的性能特性,并且调整此算法要容易得多,因为它包含的参数数量较少。此外,它还提供了从内存中消除重复字符串的选项。如果您可以消除这些重复的字符串,它可以帮助您减少总体内存占用量。

切换到Z GC算法

Z GC是一个可扩展的低延迟垃圾收集器,其主要目标是使GC暂停时间小于10毫秒。Z GC算法在Java 11和12中早期版本中都可用,因此如果您的应用程序在其中一个版本上运行,您可以将其视为并行标记扫描替代方案。

 

参考:

https://blog.csdn.net/losetowin/article/details/78569001

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值