zoukankan      html  css  js  c++  java
  • JVM调优

    记一次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或者去Oracle文档查看详细介绍

    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这块不够大的指标就看吞吐量和暂停时间,更细的指标需要大家一起探索

  • 相关阅读:
    System.Web.HttpRequestValidationException——从客户端检测到危险的Request值
    SignalR 实现web浏览器客户端与服务端的推送功能
    MVC4项目中验证用户登录一个特性就搞定
    C# winform 上传文件到服务器
    解决memcached不能远程访问的问题
    MVC4验证用户登录特性实现方法
    IIS增加并发数
    IIS处理并发请求时出现的问题及解决
    jQuery使用ajax跨域获取数据
    jQuery调用WCF服务传递JSON对象
  • 原文地址:https://www.cnblogs.com/huangwentian/p/10376002.html
Copyright © 2011-2022 走看看