本文共 1518 字,大约阅读时间需要 5 分钟。
高级程序员必不可少的技能,这个也是高薪必问的问题
能够有效通过 JVM 调优提升系统性能的人往往被人们冠以”大牛”、”大师”之类的称呼。
-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,那么下面一步做调整。
-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或者去查看详细介绍新生代,老年代分配的空间,以及使用的内存峰值
吞吐量及暂停时间:
-XX:+UseG1GC
看起来吞吐量也降低了,暂停时间也增加了。
这个参数不是硬性要求,JVM只是会尽最大的努力来达到这个要求,但是还是可能超过这个值
-XX:MaxGCPauseMillis=50
貌似没啥变化,就不贴图了
新增参数,初始堆占用百分比:-XX:InitiatingHeapOccupancyPercent=50
看起来效果也不是特别好
增加垃圾收集器的并发线程数:,效果反而更差了。
-XX:ParallelGCThreads=20 //设置并行回收时GC的线程数-XX:ConcGCThreads=5
G1的垃圾收集器阶段:
-XX:+UseConcMarkSweepGC
效果好些还是不如最初的状态
-XX:+UseParallelGC
对JVM这块不够大的指标就看吞吐量和暂停时间,更细的指标需要大家一起探索
转载地址:http://lkabl.baihongyu.com/