记一次JVM调优

调优参考:https://developer.aliyun.com/article/690392

高级程序员必不可少的技能,这个也是高薪必问的问题

能够有效通过 JVM 调优提升系统性能的人往往被人们冠以”大牛”、”大师”之类的称呼。

过程

  1. 在项目启动时加上必要的参数
-XX:+PrintGC -XX:+PrintGCCause -XX:+PrintGCDateStamps -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -Xloggc:/Users/aihe/idea/idea_gc.txt -XX:+DisableExplicitGC  -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/home/issue_error

这一步gceasy.io网站上,直接就给了提示,增加metaspace的大小,在参数设置中,我们没有看到设置metaspace,那么下面一步做调整。

image
  1. 新生代,MetaSpace不够用,增加如下参数
    初始堆内存与最大堆内存大小设为一致,这样虚拟机一次性的分配内存,而不至于在初始堆大小不够用又向系统分配内存
-Xmx2048m -Xms2048m -Xmn1024m -XX:MetaspaceSize=512m

这次参数变更为如下:

-Dfile.encoding=UTF-8
-Dsun.io.useCanonCaches=false
-Djava.net.preferIPv4Stack=true
-XX:-OmitStackTraceInFastThrow
-Xverify:none
-XX:+PrintGC
-XX:+PrintGCCause
-XX:+PrintGCDateStamps
-XX:+PrintGCDetails
-XX:+PrintGCTimeStamps
-Xloggc:/Users/aihe/idea/idea_gc.txt
-XX:+DisableExplicitGC
-Xmx2048m
-Xms2048m
-Xmn1024m
-XX:MetaspaceSize=521m

想查看每个具体的属性含义可以用:
java -XX:+PrintFlagsFinal或者去Oracle文档查看详细介绍

  1. 启动idea,打开项目,在gceasy.io网站上分析垃圾收集日志, 可以看到几个常用的指标:

新生代,老年代分配的空间,以及使用的内存峰值


image

吞吐量及暂停时间:

  • 吞吐量:吞吐量是指应用程序线程用时占程序总用时的比例
  • 暂停时间:指一个时间段内应用程序线程让与 GC 线程执行而完全暂停。
image
  1. 换一下垃圾收集器试试
-XX:+UseG1GC

看起来吞吐量也降低了,暂停时间也增加了。


image
image
  1. 新增一个GC参数,最大的停顿时间为50ms,这个参数

这个参数不是硬性要求,JVM只是会尽最大的努力来达到这个要求,但是还是可能超过这个值

-XX:MaxGCPauseMillis=50

貌似没啥变化,就不贴图了
新增参数,初始堆占用百分比:

-XX:InitiatingHeapOccupancyPercent=50

看起来效果也不是特别好


image

增加垃圾收集器的并发线程数:,效果反而更差了。

-XX:ParallelGCThreads=20 //设置并行回收时GC的线程数
-XX:ConcGCThreads=5

G1的垃圾收集器阶段:

  • 初始标记
  • 并发标记
  • 最终标记
  • 筛选回收
  1. 用一下CMS垃圾收集器看看
-XX:+UseConcMarkSweepGC

效果好些还是不如最初的状态

image
  1. 我们还是用最开始的垃圾收集器组合吧。
image
-XX:+UseParallelGC

最后

对JVM这块不够大的指标就看吞吐量和暂停时间,更细的指标需要大家一起探索

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Java 虚拟机有自己完善的硬件架构, 如处理器、堆栈、寄存器等,还具有相应的指令系统。JVM 屏蔽了与具体操作系...
    尹小凯阅读 1,705评论 0 10
  • 这篇文章是我之前翻阅了不少的书籍以及从网络上收集的一些资料的整理,因此不免有一些不准确的地方,同时不同JDK版本的...
    高广超阅读 15,707评论 3 83
  • 工作之余,想总结一下JVM相关知识。 Java运行时数据区: Java虚拟机在执行Java程序的过程中会将其管理的...
    Huang远阅读 644评论 0 2
  • 1.什么是垃圾回收? 垃圾回收(Garbage Collection)是Java虚拟机(JVM)垃圾回收器提供...
    简欲明心阅读 89,838评论 17 311
  • 原文阅读 前言 这段时间懈怠了,罪过! 最近看到有同事也开始用上了微信公众号写博客了,挺好的~给他们点赞,这博客我...
    码农戏码阅读 6,018评论 2 31