當(dāng)前位置:首頁 > 公眾號(hào)精選 > 架構(gòu)師社區(qū)
[導(dǎo)讀]本實(shí)驗(yàn)的目的是講解 JVM 的三大參數(shù)類型。在JVM調(diào)優(yōu)中用到的最多的 XX 參數(shù),而如何去查看和設(shè)置 JVM 的 XX 參數(shù)也是調(diào)優(yōu)的基本功,本節(jié)以實(shí)驗(yàn)的方式講解 JVM 參數(shù)的查看和設(shè)置,希望大家能有所啟發(fā)。

來源 | 悟空聊架構(gòu)(ID:PassJava666)

本實(shí)驗(yàn)的目的是講解 JVM 的三大參數(shù)類型。在JVM調(diào)優(yōu)中用到的最多的 XX 參數(shù),而如何去查看和設(shè)置 JVM 的 XX 參數(shù)也是調(diào)優(yōu)的基本功,本節(jié)以實(shí)驗(yàn)的方式講解 JVM 參數(shù)的查看和設(shè)置。希望大家能有所啟發(fā)。

搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了!

標(biāo)配參數(shù)

常見標(biāo)配參數(shù)

  • -version,獲取JDK版本

  • -help,獲取幫助

  • -showverision,獲取JDK版本和幫助

動(dòng)手實(shí)驗(yàn) 1 - 查看標(biāo)配參數(shù)

實(shí)驗(yàn)步驟:

  • 查看Java JDK 版本
java?-version
搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! 實(shí)驗(yàn) 1-1

可以看到Java JDK 版本為1.8.0_131

  • 查看 Java 幫助文檔
java?-help
搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! 實(shí)驗(yàn) 1-2
  • 查看版本和幫助文檔
java?-showversion
搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! 實(shí)驗(yàn) 1-3

X 參數(shù)

X 參數(shù)簡(jiǎn)介

我們常用的javac大家都知道是把java代碼編譯成 class 文 Java 文件,那么 class 文件怎么去執(zhí)行呢?這里用到了三個(gè)X參數(shù)來說明 class 文件怎么在虛擬機(jī)里面跑起來的。

  • -Xint:直接解釋執(zhí)行
  • -Xcomp:先編譯成本地代碼再執(zhí)行
  • -XMixed:混合模式(既有編譯執(zhí)行也有解釋執(zhí)行)

動(dòng)手實(shí)驗(yàn) 2 - 查看和配置X參數(shù)

  • 查看版本
java?-version

在WebIDE的控制臺(tái)窗口執(zhí)行Java -version 后,可以看到我的環(huán)境是混合模式執(zhí)行java程序的。

搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! 實(shí)驗(yàn) 2-1
  • 修改編譯模式為解釋執(zhí)行模式
java?-Xint?-version

在WebIDE的控制臺(tái)窗口執(zhí)行命令

搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! 實(shí)驗(yàn) 2-2
  • 修改編譯模式為只編譯模式
java?-Xcomp?-version
搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! 實(shí)驗(yàn) 2-3

XX 參數(shù)

XX? 參數(shù)簡(jiǎn)介

XX 參數(shù)有兩種類型,一種是 Boolean 類型,另外一種是鍵值對(duì)類型。

  • Boolean 類型
    • 公式: -XX:+某個(gè)屬性或者, -XX:-某個(gè)屬性+表示開啟了這個(gè)屬性,-表示關(guān)閉了這個(gè)屬性。
    • 案例: -XX:-PrintGCDetails,表示關(guān)閉了GC詳情輸出
  • key-value類型
    • 公式: -XX:屬性key=屬性value
    • 案例: -XX:屬性metaspace=2000000,設(shè)置Java元空間的值為2000000。

動(dòng)手實(shí)驗(yàn) 3 - 查看參數(shù)是否開啟

本實(shí)驗(yàn)主要講解如下內(nèi)容:查看運(yùn)行的 Java 程序 PrintGCDetails 參數(shù)是否開啟

  • 編寫一個(gè)一直運(yùn)行的 Java 程序
  • 查看該應(yīng)用程序的進(jìn)程 id
  • 查看該進(jìn)程的 GCDetail 參數(shù)是否開啟

在 WebIDE 上右鍵單擊菜單,選擇 New File 創(chuàng)建新文件

搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! New File

創(chuàng)建文件名為 demoXXparam.java

搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! 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 的控制臺(tái)窗口編譯 demoXXparam.java 代碼

javac?demoXXparam.java
搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! 編譯代碼

編譯之后,會(huì)在當(dāng)前文件夾產(chǎn)生我們所編寫的 ?demoXXparam類的 demoXXparam.class字節(jié)碼文件

搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! 生產(chǎn)Class文件

在 WebIDE 上運(yùn)行 demoXXparam 代碼

java?demoXXparam
搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! 運(yùn)行Java程序

輸出:

hello?XX?params

在 WebIDE 中新開一個(gè)控制臺(tái)窗口

Terminal->New Terminal

搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! 開啟新控制臺(tái)窗口

查看所有的運(yùn)行的java程序,-l 表示打印出class文件的包名

jps?-l
搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! jps

發(fā)現(xiàn)demoXXparam進(jìn)程的id為 518

查看 demoXXparam 程序是否開啟了PrintGCDetails這個(gè)參數(shù)

PrintGCDetails: 在發(fā)生垃圾回收時(shí)打印內(nèi)存回收日志,并在進(jìn)程退出時(shí)輸出當(dāng)前內(nèi)存各區(qū)域分配情況

jinfo?-flag?PrintGCDetails?518
搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! jinfo

結(jié)果如下:

-XX:-PrintGCDetails

上面提到 ?-號(hào)表示關(guān)閉,所以當(dāng)前 demo 程序沒有開啟 PrintGCDetails參數(shù)。

動(dòng)手實(shí)驗(yàn) 4 ?- 開啟參數(shù)

  • 在 WebIDE 控制臺(tái)強(qiáng)制退出demoXXparam程序
ctrl?+?c
  • 然后清理屏幕
clear
  • 然后以參數(shù) -XX:+PrintGCDetails運(yùn)行 demoXXparam 程序
java?-XX:+PrintGCDetails?demoXXparam
搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! 實(shí)驗(yàn) 4
  • 輸出:
hello?XX?params

查看demoXXparam進(jìn)程的 id

搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! 進(jìn)程 id

可以看到demoXXparam進(jìn)程 id 為 1225

查看 demoXXparam 的配置參數(shù) PrintGCDetails

打開一個(gè)新的控制臺(tái)窗口,執(zhí)行以下命令來查看進(jìn)程為 1225 的 PrintGCDetails參數(shù)是否開啟

jinfo?-flag?PrintGCDetails?1225
搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! PrintGCDetails 參數(shù)

可以看到PrintGCDetails是開啟的,+號(hào)表示開啟。

動(dòng)手實(shí)驗(yàn) 5 - Key-Value 類型參數(shù)值

查看元空間的值

jinfo?-flag?MetaspaceSize?526
搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! MetaspaceSize 大小

由此可以得出元空間的大小為 21 M。

設(shè)置元空間的值為 128 M

java?-XX:MetaspaceSize=128m?demoXXparam

查看元空間的大小

jinfo?-flag?MetaspaceSize?1062
搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! 調(diào)整元空間大小

最常見的 -Xms 和 -Xmx 屬于哪種參數(shù)?

  • -Xms參數(shù)代表-XX:InitialHeapSize ,初始化堆內(nèi)存(默認(rèn)只會(huì)用最大物理內(nèi)存的64分1)
  • -Xmx:參數(shù)代表-XX:MaxHeapSize ,大堆內(nèi)存(默認(rèn)只會(huì)用最大物理內(nèi)存的4分1)

起了別名,但還是屬于XX參數(shù)。

動(dòng)手實(shí)驗(yàn) 6 - 設(shè)置 -XX:InitialHeapSize 和 -XX:MaxHeapSize 的值。

java?-XX:InitialHeapSize=200m?demoXXparam
或者
java?-Xms200m?demoXXparam

查看 InitialHeapSize 參數(shù)的值,大小為 200 M。

搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! 設(shè)置 InitialHeapSize
java?-XX:MaxHeapSize=200M?demoXXparam
或者
java?-Xmx200m?demoXXparam

查看 MaxHeapSize 參數(shù)的值,大小為 200 M。

搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! 設(shè)置 MaxHeapSize

擴(kuò)展:查看 Java 程序已設(shè)置的所有參數(shù)值

jinfo?-flags?<進(jìn)程id>
搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! mark
  • Non-Defalut VM flags 代表參數(shù)類型是JVM自帶的參數(shù)。
  • Command line 代表是用戶自定義的參數(shù)

如何查看出廠設(shè)置和自定義設(shè)置的XX配置項(xiàng)

動(dòng)手實(shí)驗(yàn) 7 - 查看出廠默認(rèn)設(shè)置的所有XX配置項(xiàng)

java?-XX:+PrintFlagsInitial?-version
搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! PrintFlagsInitial

動(dòng)手實(shí)驗(yàn) 8 - 查看 JVM 當(dāng)前所有XX配置項(xiàng)

java?-XX:+PrintFlagsFinal?-version
搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! PrintFlagsFinal

我們可以看到幾個(gè)關(guān)鍵信息:

  • [Global flags]:全局參數(shù),如果自定義修改了某個(gè)應(yīng)用的參數(shù),并不會(huì)修改全局參數(shù)

    比如之前我們修改了MetaspaceSize為128m,但列表里面還是21m。

搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! Global flags
  • :=:參數(shù)已被修改,如下圖所示InitialHeapSize初始化堆內(nèi)存參數(shù)已修改為264241152

    總結(jié)如下:

搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! 出廠設(shè)置和自定義參數(shù)設(shè)置

動(dòng)手實(shí)驗(yàn) 9 - 運(yùn)行程序時(shí)打印XX配置選項(xiàng)

java?-XX:+PrintFlagsFinal?-XX:+InitialHeapSize=150M?demoXXparam

可以看到修改后的值為 157286400(150 M)

搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! 運(yùn)行程序時(shí)打印XX配置選項(xiàng)

動(dòng)手實(shí)驗(yàn) 10 - 查看 JVM 自動(dòng)配置的或者用戶手動(dòng)設(shè)置的XX選項(xiàng)(非應(yīng)用程序的)

java?-XX:+PrintCommandLineFlags?-version

會(huì)打印出如下參數(shù):

搞懂JVM的三大參數(shù)類型,就靠這十個(gè)小實(shí)驗(yàn)了! JVM 自動(dòng)配置的XX選項(xiàng)

實(shí)驗(yàn)總結(jié)

本節(jié)實(shí)驗(yàn)課學(xué)習(xí)了如何查看基本參數(shù)、X參數(shù)、XX參數(shù)和設(shè)置XX參數(shù)。以及用好jps和jinfo工具來查看進(jìn)程和設(shè)置參數(shù)。

JVM性能調(diào)優(yōu)還有很多要講的,一篇是講不完的,我會(huì)分成幾篇來為大家講述,形式主要以小實(shí)驗(yàn)的方式來為大家講解。


免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場(chǎng),如有問題,請(qǐng)聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉