JVM垃圾回收调优入门

19 篇文章 0 订阅
3 篇文章 0 订阅

JVM垃圾回收调优入门

垃圾回收是程序运行中影响性能很关键的一环,分析垃圾回收情况并对其参数进行一些调优是非常有必要的。
主要指标:吞吐量、停顿时间、GC原因
工具:gceasy、gcviewer

选择垃圾回收器

  • 并行收集器
    介绍:这里的并行是指垃圾回收线程并行回收,而不是垃圾回收线程和应用程序线程并行,故在进行垃圾回收的时候,应用程序会被暂停执行。
    特点:吞吐量优先,不过会影响程序的响应时间,影响用户体验。
    开启:-XX:+UseParallelGC -XX:+UseParallelOldGC

  • 并发收集器
    CMS垃圾收集器:
    分区:Eden、from survival、to survival、Old有明确界限
    新手代GC过程:复制算法(STW)
    老年代GC过程:初始标记(STW)-》并发标记-》最终标记(STW)-》全局清除
    特点:程序停顿的时间很短,提高了响应速度,不过在进行full GC时时间是不可控的。
    开启:-XX:+UseConcMarkSweepGC
    G1垃圾收集器:
    分区:E、S、O区并没有明确界限,转而使用region概念
    新手代GC过程:复制算法(STW)
    老年代GC过程:初始标记(STW)-》并发标记-》最终标记(STW)-》筛选清除
    特点:把三块内存变成了几百块内存,内存块的粒度变小了,从而可以垃圾回收工作更彻底的并行化,并且可以设置垃圾回收时间,使得停顿时间是可预期的,稳定性更好
    开启:-XX:+UseG1GC

CMS与G1详细对比链接

调优思路

  • 先开启日志,导出GC日志后进行分析。
    比如在Tomcat中开启:
-Xloggc:/usr/tomcat/apache-tomcat-7.0.81/logs/gc.$$.log
  • 导出日志下载到本地查看
  • 可以使用工具可视化查看,如gceasy、开源项目GCviewer
  • 查看主要指标:吞吐量、停顿时间、GC原因
  • GC原因分析:
    1、经常的进行堆区的垃圾回收,可以根据服务器配置调整堆大小 -Xms -Xmx
    2、经常出现元空间的垃圾回收,可以调节-XX:MetaspaceSize -XX:MaxMetaspaceSize
    3、使用G1垃圾收集器,根据需求调节暂停目标时间 -XX:MaxGCPauseMillis,不过不要调的太苛刻,可能影响吞吐量
    4、GC优化:禁止显式GC -XX:+DisableExplicitGC
    调整新生代到老年代年龄限制 -XX:MaxTenuringThreshold
    设置大对象直接进入老年代:-XX:PretenureSizeThreshold
  • 进行参数调优后测试,对比主要指标得出调优结果

ps:更改参数要逐个修改测试效果,参数更改在配置文件中进行修改,如Tomcat中是在bin/catalina.sh中的JAVA_OPTS进行添加修改。

总结
根据需要选择对应的垃圾收集器,然后通过GC日志查看对于的指标以及gc原因,分析后进行参数的调优,调优过程是需要多次测试验证,也需要一定的实践经验,后续有相关的实践经验会再次记录下来,本次主要以入门为主,知道大概思路以备不时之需。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值