博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
记一次JVM调优
阅读量:6886 次
发布时间:2019-06-27

本文共 1518 字,大约阅读时间需要 5 分钟。

记一次JVM调优

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

能够有效通过 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,那么下面一步做调整。

  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或者去查看详细介绍

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

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

吞吐量及暂停时间:

  • 吞吐量:吞吐量是指应用程序线程用时占程序总用时的比例
  • 暂停时间:指一个时间段内应用程序线程让与 GC 线程执行而完全暂停。

  1. 换一下垃圾收集器试试
-XX:+UseG1GC

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

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

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

-XX:MaxGCPauseMillis=50

貌似没啥变化,就不贴图了

新增参数,初始堆占用百分比:

-XX:InitiatingHeapOccupancyPercent=50

看起来效果也不是特别好

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

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

G1的垃圾收集器阶段:

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

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

  1. 我们还是用最开始的垃圾收集器组合吧。

-XX:+UseParallelGC

最后

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

转载地址:http://lkabl.baihongyu.com/

你可能感兴趣的文章
威胁快报|Nexus Repository Manager 3新漏洞已被用于挖矿木马传播,建议用户尽快修复...
查看>>
关于redis,学会这8点就够了
查看>>
阿里小二的日常工作要被TA们“接管”了!
查看>>
权限框架Shiro学习之表结构设计
查看>>
Nginx 服务器之速率限制
查看>>
JavaScript实现多态和继承的封装操作示例
查看>>
大数据平台开发公司有哪些?
查看>>
用vs运行cmake后的工程
查看>>
1.1 函数定义 1.2 函数的参数 1.3 函数的默认参数
查看>>
不学无数——Java动态代理
查看>>
如何使用手机、家庭宽带作为爬虫的代理服务器
查看>>
Python黑客攻击的几种技术,你得了解一下
查看>>
你真的懂了redis的数据结构吗?redis内部数据结构和外部数据结构揭秘
查看>>
Ubuntu10.04LTS配置Hadoop1.0.1+HBase 0.92.0
查看>>
ST教学分析:相同行为连续数
查看>>
status2 转义输出
查看>>
[清华集训2016]如何优雅地求和——NTT
查看>>
JavaScript 原型链例子讲解
查看>>
书摘---创业36条军规7:业务的五个问题
查看>>
Linux学习-第三节课
查看>>