搞懂JVM的三大參數(shù)類型,就靠這十個小實驗了!
來源 | 悟空聊架構(gòu)(ID:PassJava666)
本實驗的目的是講解 JVM 的三大參數(shù)類型。在JVM調(diào)優(yōu)中用到的最多的 XX 參數(shù),而如何去查看和設(shè)置 JVM 的 XX 參數(shù)也是調(diào)優(yōu)的基本功,本節(jié)以實驗的方式講解 JVM 參數(shù)的查看和設(shè)置。希望大家能有所啟發(fā)。
標(biāo)配參數(shù)
常見標(biāo)配參數(shù)
-
-version,獲取JDK版本
-
-help,獲取幫助
-
-showverision,獲取JDK版本和幫助
動手實驗 1 - 查看標(biāo)配參數(shù)
實驗步驟:
- 查看Java JDK 版本
java?-version實驗 1-1
可以看到Java JDK 版本為1.8.0_131
- 查看 Java 幫助文檔
java?-help實驗 1-2
- 查看版本和幫助文檔
java?-showversion實驗 1-3
X 參數(shù)
X 參數(shù)簡介
我們常用的javac大家都知道是把java代碼編譯成 class 文 Java 文件,那么 class 文件怎么去執(zhí)行呢?這里用到了三個X參數(shù)來說明 class 文件怎么在虛擬機里面跑起來的。
-
-Xint:直接解釋執(zhí)行
-
-Xcomp:先編譯成本地代碼再執(zhí)行
-
-XMixed:混合模式(既有編譯執(zhí)行也有解釋執(zhí)行)
動手實驗 2 - 查看和配置X參數(shù)
-
查看版本
java?-version
在WebIDE的控制臺窗口執(zhí)行Java -version 后,可以看到我的環(huán)境是混合模式執(zhí)行java程序的。
實驗 2-1
-
修改編譯模式為解釋執(zhí)行模式
java?-Xint?-version
在WebIDE的控制臺窗口執(zhí)行命令
實驗 2-2
-
修改編譯模式為只編譯模式
java?-Xcomp?-version
實驗 2-3
XX 參數(shù)
XX? 參數(shù)簡介
XX 參數(shù)有兩種類型,一種是 Boolean 類型,另外一種是鍵值對類型。
-
Boolean 類型
-
公式:
-XX:+某個屬性或者,
-XX:-某個屬性+表示開啟了這個屬性,-表示關(guān)閉了這個屬性。
-
案例:
-XX:-PrintGCDetails,表示關(guān)閉了GC詳情輸出
-
key-value類型
-
公式:
-XX:屬性key=屬性value
-
案例:
-XX:屬性metaspace=2000000,設(shè)置Java元空間的值為2000000。
動手實驗 3 - 查看參數(shù)是否開啟
本實驗主要講解如下內(nèi)容:查看運行的 Java 程序 PrintGCDetails 參數(shù)是否開啟
-
編寫一個一直運行的 Java 程序
-
查看該應(yīng)用程序的進程 id
-
查看該進程的 GCDetail 參數(shù)是否開啟
在 WebIDE 上右鍵單擊菜單,選擇 New File 創(chuàng)建新文件
New File
創(chuàng)建文件名為 demoXXparam.java
demoXXparam.java
在 WebIDE 上編寫 demoXXparam.java
public class demoXXparam { public static void main(String[]?args) throws InterruptedException {
????????System.out.println("hello?XX?params");
????????Thread.sleep(Integer.MAX_VALUE);
????}
}
在 WebIDE 的控制臺窗口編譯 demoXXparam.java 代碼
javac?demoXXparam.java
編譯代碼
編譯之后,會在當(dāng)前文件夾產(chǎn)生我們所編寫的 ?demoXXparam類的 demoXXparam.class字節(jié)碼文件
生產(chǎn)Class文件
在 WebIDE 上運行 demoXXparam 代碼
java?demoXXparam
運行Java程序
輸出:
hello?XX?params
在 WebIDE 中新開一個控制臺窗口
Terminal->New Terminal
開啟新控制臺窗口
查看所有的運行的java程序,-l 表示打印出class文件的包名
jps?-l
jps
發(fā)現(xiàn)demoXXparam進程的id為 518
查看 demoXXparam 程序是否開啟了PrintGCDetails這個參數(shù)
PrintGCDetails: 在發(fā)生垃圾回收時打印內(nèi)存回收日志,并在進程退出時輸出當(dāng)前內(nèi)存各區(qū)域分配情況
jinfo?-flag?PrintGCDetails?518
jinfo
結(jié)果如下:
-XX:-PrintGCDetails
上面提到 ?-號表示關(guān)閉,所以當(dāng)前 demo 程序沒有開啟 PrintGCDetails參數(shù)。
動手實驗 4 ?- 開啟參數(shù)
-
在 WebIDE 控制臺強制退出demoXXparam程序
ctrl?+?c
-
然后清理屏幕
clear
-
然后以參數(shù)
-XX:+PrintGCDetails運行 demoXXparam 程序
java?-XX:+PrintGCDetails?demoXXparam
實驗 4
-
輸出:
hello?XX?params
查看demoXXparam進程的 id
進程 id
可以看到demoXXparam進程 id 為 1225
查看 demoXXparam 的配置參數(shù) PrintGCDetails
打開一個新的控制臺窗口,執(zhí)行以下命令來查看進程為 1225 的 PrintGCDetails參數(shù)是否開啟
jinfo?-flag?PrintGCDetails?1225
PrintGCDetails 參數(shù)
可以看到PrintGCDetails是開啟的,+號表示開啟。
動手實驗 5 - Key-Value 類型參數(shù)值
查看元空間的值
jinfo?-flag?MetaspaceSize?526
MetaspaceSize 大小
由此可以得出元空間的大小為 21 M。
設(shè)置元空間的值為 128 M
java?-XX:MetaspaceSize=128m?demoXXparam
查看元空間的大小
jinfo?-flag?MetaspaceSize?1062
調(diào)整元空間大小
最常見的 -Xms 和 -Xmx 屬于哪種參數(shù)?
-
-Xms參數(shù)代表-XX:InitialHeapSize ,初始化堆內(nèi)存(默認只會用最大物理內(nèi)存的64分1)
-
-Xmx:參數(shù)代表-XX:MaxHeapSize ,大堆內(nèi)存(默認只會用最大物理內(nèi)存的4分1)
起了別名,但還是屬于XX參數(shù)。
動手實驗 6 - 設(shè)置 -XX:InitialHeapSize 和 -XX:MaxHeapSize 的值。
java?-XX:InitialHeapSize=200m?demoXXparam
或者
java?-Xms200m?demoXXparam
查看 InitialHeapSize 參數(shù)的值,大小為 200 M。
設(shè)置 InitialHeapSize
java?-XX:MaxHeapSize=200M?demoXXparam
或者
java?-Xmx200m?demoXXparam
查看 MaxHeapSize 參數(shù)的值,大小為 200 M。
設(shè)置 MaxHeapSize
擴展:查看 Java 程序已設(shè)置的所有參數(shù)值
jinfo?-flags?<進程id>
mark
-
Non-Defalut VM flags 代表參數(shù)類型是JVM自帶的參數(shù)。
-
Command line 代表是用戶自定義的參數(shù)
如何查看出廠設(shè)置和自定義設(shè)置的XX配置項
動手實驗 7 - 查看出廠默認設(shè)置的所有XX配置項
java?-XX:+PrintFlagsInitial?-version
PrintFlagsInitial
動手實驗 8 - 查看 JVM 當(dāng)前所有XX配置項
java?-XX:+PrintFlagsFinal?-version
PrintFlagsFinal
我們可以看到幾個關(guān)鍵信息:
-
[Global flags]:全局參數(shù),如果自定義修改了某個應(yīng)用的參數(shù),并不會修改全局參數(shù)
比如之前我們修改了MetaspaceSize為128m,但列表里面還是21m。
Global flags
-
:=:參數(shù)已被修改,如下圖所示InitialHeapSize初始化堆內(nèi)存參數(shù)已修改為264241152
總結(jié)如下:
出廠設(shè)置和自定義參數(shù)設(shè)置
動手實驗 9 - 運行程序時打印XX配置選項
java?-XX:+PrintFlagsFinal?-XX:+InitialHeapSize=150M?demoXXparam
可以看到修改后的值為 157286400(150 M)
運行程序時打印XX配置選項
動手實驗 10 - 查看 JVM 自動配置的或者用戶手動設(shè)置的XX選項(非應(yīng)用程序的)
java?-XX:+PrintCommandLineFlags?-version
會打印出如下參數(shù):
JVM 自動配置的XX選項
實驗總結(jié)
本節(jié)實驗課學(xué)習(xí)了如何查看基本參數(shù)、X參數(shù)、XX參數(shù)和設(shè)置XX參數(shù)。以及用好jps和jinfo工具來查看進程和設(shè)置參數(shù)。
JVM性能調(diào)優(yōu)還有很多要講的,一篇是講不完的,我會分成幾篇來為大家講述,形式主要以小實驗的方式來為大家講解。
免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!