jvm认识与探究(六)GC调优

一、GC调优

1.发生GC的情况

a.Eden区或者Survivor区无法分配新的对象内存空间
b.Old区内存空间不足
c.方法区空间不足
d.调用System.gc()方法主动通知触发GC

2.GC日志

设置运行环境参数得到GC日志可查看默认使用的垃圾收集器

-XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps -Xloggc:gc.log

设置使用G1GC并打印日志,真实环境根据之前文档提供使用各种垃圾收集器的场景设置使用

-XX:+UseG1GC -Xloggc:gc.log

官网G1GC日志格式参照:https://blogs.oracle.com/poonam/understanding-g1-gc-logs

Java HotSpot(TM) 64-Bit Server VM (25.111-b14) for windows-amd64 JRE (1.8.0_111-b14), built on Sep 22 2016 19:24:05 by "java_re" with MS VC++ 10.0 (VS2010)
Memory: 4k page, physical 8259336k(1932188k free), swap 12504700k(2493292k free)
CommandLine flags: -XX:-BytecodeVerificationLocal -XX:-BytecodeVerificationRemote -XX:InitialHeapSize=132149376 -XX:+ManagementServer -XX:MaxHeapSize=2114390016 -XX:+PrintGC -XX:+PrintGCTimeStamps -XX:TieredStopAtLevel=1 -XX:+UseCompressedClassPointers -XX:+UseCompressedOops -XX:+UseG1GC -XX:-UseLargePagesIndividualAllocation 
1.656: [GC pause (G1 Evacuation Pause) (young) 14M->2354K(128M), 0.0035691 secs]
2.112: [GC pause (G1 Evacuation Pause) (young) 20M->5497K(128M), 0.0061858 secs]
2.838: [GC pause (G1 Evacuation Pause) (young) 78M->13M(128M), 0.0109968 secs]
2.982: [GC pause (Metadata GC Threshold) (young) (initial-mark) 31M->9574K(128M), 0.0062685 secs]
2.988: [GC concurrent-root-region-scan-start]
2.996: [GC concurrent-root-region-scan-end, 0.0076272 secs]
2.996: [GC concurrent-mark-start]
3.003: [GC concurrent-mark-end, 0.0068325 secs]
3.003: [GC remark, 0.0064961 secs]
3.010: [GC cleanup 11M->11M(128M), 0.0008290 secs]
3.010: [GC concurrent-cleanup-start]
3.010: [GC concurrent-cleanup-end, 0.0000090 secs]
3.703: [GC pause (G1 Evacuation Pause) (young) 78M->14M(128M), 0.0123108 secs]
4.382: [GC pause (G1 Evacuation Pause) (young) 80M->18M(128M), 0.0154807 secs]

可从文件最长一行看到代码-XX:+UseG1GC表示使用G1GC

3.使用GCViewer查看调优指标

Throughput:吞吐量(越高越优)

在这里插入图片描述

Avg Pause:平均停顿时间(越短越优)

在这里插入图片描述

number of pauses:gc停顿次数(越少越优)

在这里插入图片描述

以上三个参数就是衡量jvm垃圾回收的指标

可通过不断调整内存大小、停顿时间、G1GC堆使用率等来调整达到三方面平均最优的一个平衡

内存大小调整参数设置:
-XX:MetaspaceSize=100M 方法区大小
-Xms300M 初始堆内存空间
-Xmx300M 最大堆内存空间

G1GC最大停顿时间参数设置:
-XX:MaxGCPauseMillis=20 设置最大GC停顿时间指标

G1用它来触发并发GC周期,基于整个堆的使用率,而不只是某一代内存的 使用比例。值为 0 则表示“一直执行GC循环)’. 默认值为 45 (例如, 全部的 45% 或者使用了45%).
并发GC时堆内存占用百分比参数设置:
-XX:InitiatingHeapOccupancyPercent=45

官网G1GC调优指南:https://docs.oracle.com/javase/8/docs/technotes/guides/vm/gctuning/g1_gc_tuning.html#recommendations

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值