本篇文章我們就來給大家介紹垃圾收集器的 JVM 參數配置。
JVM參數有很多,其實我們直接使用默認的JVM參數,不去修改都可以滿足大多數情況。但是如果你想在有限的硬件資源下,部署的系統達到最大的運行效率,那么進行相關的JVM參數設置是必不可少的。下面我們就來對這些JVM參數進行詳細的介紹。JVM參數主要分為以下三種(可以根據書寫形式來區分):
1、標準參數
標準參數,顧名思義,標準參數中包括功能以及輸出的結果都是很穩定的,基本上不會隨著JVM版本的變化而變化。
我們可以通過 -help 命令來檢索出所有標準參數。
關于這些命令的詳細解釋,可以參考官網:https://docs.oracle.com/javase/7/docs/technotes/tools/solaris/java.html
-help 也是一個標準參數,再比如使用比較多的 -version也是。
①、-version
顯示Java的版本信息。
2、X 參數
對應前面講的標準化參數,這是非標準化參數。表示在將來的JVM版本中可能會發生改變,但是這類以 -X開始的參數變化的比較小。
我們可以通過 Java -X 命令來檢索所有-X 參數。
關于這些參數的介紹,其實上圖的中文解釋很清楚了,這里我們不作過多的介紹。
3、XX參數
這是我們日常開發中接觸到最多的參數類型。這也是非標準化參數,相對來說不穩定,隨著JVM版本的變化可能會發生變化,主要用于JVM調優和debug。
注意:這種參數是我們后續介紹JVM調優講解最多的參數。
該參數的書寫形式又分為兩大類:
①、Boolean類型 格式:-XX:[+-]表示啟用或者禁用name屬性。
例子:-XX:+UseG1GC(表示啟用G1垃圾收集器)
②、Key-Value類型 格式:-XX:=表示name的屬性值為value。
例子:-XX:MaxGCPauseMillis=500(表示設置GC的最大停頓時間是500ms)
4、參數詳解
1、打印已經被用戶或者當前虛擬機設置過的參數
-XX:+PrintCommandLineFlags
比如:
2、最大堆和最小堆內存設置
-Xms512M:設置堆內存初始值為512M
-Xmx1024M:設置堆內存最大值為1024M
這里的ms是memory start的簡稱,mx是memory max的簡稱,分別代表最小堆容量和最大堆容量。但是別看這里是-X參數,其實這是-XX參數,等價于:
-XX:InitialHeapSize
-XX:MaxHeapSize
在通常情況下,服務器項目在運行過程中,堆空間會不斷的收縮與擴張,勢必會造成不必要的系統壓力。所以在生產環境中,JVM的Xms和Xmx要設置成一樣的,能夠避免GC在調整堆大小帶來的不必要的壓力。
3、Dump異??煺找约耙晕募问綄С?/p>
-XX:+HeapDumpOnOutOfMemoryError
-XX:HeapDumpPath
堆內存出現OOM的概率是所有內存耗盡異常中最高的,出錯時的堆內信息對解決問題非常有幫助,所以給JVM設置這個參數(-XX:+HeapDumpOnOutOfMemoryError),讓JVM遇到OOM異常時能輸出堆內信息,并通過(-XX:+HeapDumpPath)參數設置堆內存溢出快照輸出的文件地址,這對于特別是對相隔數月才出現的OOM異常尤為重要。
這兩個參數通常配套使用:
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=./
4、發送OOM后,執行一個腳本
-XX:OnOutOfMemoryError
比如這樣設置:
-XX:OnOutOfMemoryError="C:Program FilesJavajdk1.8.0_152binjconsole.exe"
表示發生OOM后,運行jconsole.exe程序。這里可以不用加“”,因為jconsole.exe路徑Program Files含有空格。
利用這個參數,我們可以在系統OOM后,自定義一個腳本,可以用來發送郵件告警信息,可以用來重啟系統等等。
5、打印gc信息
①、打印GC簡單信息
-verbose:gc
-XX:+PrintGC
一個是標準參數,一個是-XX參數,都是打印詳細的gc信息。通常會打印如下信息:
比如第一行,表示GC回收之前有12195K的內存,回收之后剩余1088K,總共內存為125951K
②、打印詳細GC信息
-XX:+PrintGCDetails
-XX:+PrintGCTimeStamps
6、指定GC日志以文件輸出
-Xloggc:./gc.log
這個在參數用于將gc日志以文件的形式輸出,更方便我們去查看日志,定位問題。
7、設置永久代大小
-XX:MaxPermSize=1280m
在JDK1.7以及以前的版本中,只有Hotspot 才有Perm區,稱為永久代,它在啟動時固定大小,很難進行調優。
在某些情況下,如果動態加載類過多,容易產生Perm區的 OOM。比如某個實際 Web 工程中,因為功能點較多,在運行過程中,要不斷動態加載很多類,就會出現類似錯誤:
"Exception in thread 'dubbo client x.x.connect' java.lang.OutOfMemoryError:PermGenspace"
為了解決這個問題,就需要在項目啟動時,設定運行參數-XX:MaxPermSize。
注意:在JDK1.8以后面的版本,使用元空間來代替永久代。在 JDK1.8以及后面的版本中,如果設定參數-XX:MaxPermSize,啟動JVM不會報錯,但是會提示:
Java Hotspot 64Bit Server VM warning:ignoring option MaxPermSize=1280m:support was removed in 8.0
8、垃圾收集器常用參數
-
內存
+關注
關注
8文章
2998瀏覽量
73882 -
參數
+關注
關注
11文章
1784瀏覽量
32086 -
JVM
+關注
關注
0文章
157瀏覽量
12207 -
收集器
+關注
關注
0文章
30瀏覽量
3126
發布評論請先 登錄
相關推薦
評論