天天看點

記一次JVM調優記一次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這塊不夠大的名額就看吞吐量和暫停時間,更細的名額需要大家一起探索