自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

秒懂JVM的三大參數(shù)類型,就靠這十個小實驗了

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

[[343690]]

作者 | 悟空哥

來源 | 悟空聊架構(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 版本

  1. java -version 

實驗 1-1

 

可以看到Java JDK 版本為1.8.0_131

  • 查看 Java 幫助文檔
  1. java -help 

實驗 1-2

 

  • 查看版本和幫助文檔
  1. 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ù)

查看版本

  1. java -version 

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

實驗 2-1

 

  • 修改編譯模式為解釋執(zhí)行模式
  1. java -Xint -version 

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

實驗 2-2

 

  • 修改編譯模式為只編譯模式
  1. 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

  1. public class demoXXparam { 
  2.     public static void main(String[] args) throws InterruptedException { 
  3.         System.out.println("hello XX params"); 
  4.         Thread.sleep(Integer.MAX_VALUE); 
  5.     } 

在 WebIDE 的控制臺窗口編譯 demoXXparam.java 代碼

  1. javac demoXXparam.java  

編譯代碼

 

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

生產(chǎn)Class文件

 

在 WebIDE 上運行 demoXXparam 代碼

  1. java demoXXparam 

運行Java程序

 

輸出:

  1. hello XX params 

在 WebIDE 中新開一個控制臺窗口

Terminal->New Terminal

開啟新控制臺窗口

 

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

  1. jps -l 

jps

 

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

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

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

  1. jinfo -flag PrintGCDetails 518 

jinfo

 

結(jié)果如下:

  1. -XX:-PrintGCDetails 

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

動手實驗 4 - 開啟參數(shù)

  • 在 WebIDE 控制臺強制退出demoXXparam程序
  1. ctrl + c 
  • 然后清理屏幕
  1. clear 
  • 然后以參數(shù) -XX:+PrintGCDetails 運行 demoXXparam 程序
  1. java -XX:+PrintGCDetails demoXXparam 

實驗 4

 

  • 輸出:
  1. hello XX params 

查看demoXXparam進程的 id

進程 id

 

可以看到demoXXparam進程 id 為 1225

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

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

  1. jinfo -flag PrintGCDetails 1225 

PrintGCDetails 參數(shù)

 

可以看到PrintGCDetails是開啟的,+號表示開啟。

動手實驗 5 - Key-Value 類型參數(shù)值

查看元空間的值

  1. jinfo -flag MetaspaceSize 526 

MetaspaceSize 大小

 

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

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

  1. java -XX:MetaspaceSize=128m demoXXparam    

查看元空間的大小

  1. jinfo -flag MetaspaceSize 1062 

調(diào)整元空間大小

 

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

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

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

動手實驗 6 - 設(shè)置 -XX:InitialHeapSize 和 -XX:MaxHeapSize 的值。

  1. java -XX:InitialHeapSize=200m demoXXparam 
  2. 或者 
  3. java -Xms200m demoXXparam 

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

設(shè)置 InitialHeapSize

  1. java -XX:MaxHeapSize=200M demoXXparam 
  2. 或者 
  3. java -Xmx200m demoXXparam 

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

 


設(shè)置 MaxHeapSize

 

 

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

  1. jinfo -flags <進程id> 

 


mark

 

 

  • Non-Defalut VM flags 代表參數(shù)類型是JVM自帶的參數(shù)。
  • Command line 代表是用戶自定義的參數(shù)

如何查看出廠設(shè)置和自定義設(shè)置的XX配置項動手實驗

7 - 查看出廠默認(rèn)設(shè)置的所有XX配置項

  1. java -XX:+PrintFlagsInitial -version  

 

 


PrintFlagsInitial

 

 

動手實驗 8 - 查看 JVM 當(dāng)前所有XX配置項

  1. 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配置選項

  1. java -XX:+PrintFlagsFinal -XX:+InitialHeapSize=150M demoXXparam 

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

運行程序時打印XX配置選項

 

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

  1. 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)還有很多要講的,一篇是講不完的,我會分成幾篇來為大家講述,形式主要以小實驗的方式來為大家講解。

本文轉(zhuǎn)載自微信公眾號「 悟空聊架構(gòu)」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請聯(lián)系 悟空聊架構(gòu)公眾號。

 

 

責(zé)任編輯:武曉燕 來源: 悟空聊架構(gòu)
相關(guān)推薦

2024-12-31 08:10:00

2017-05-10 11:08:59

2018-02-02 10:49:05

編程開發(fā)Java

2020-07-29 15:01:50

JVMGCJDK

2020-10-14 15:00:38

Python 開發(fā)編程語言

2024-01-30 00:40:10

2021-04-16 08:11:07

程序體積優(yōu)化

2024-04-29 08:35:29

監(jiān)控Kafka集群

2021-10-18 08:01:44

TS語言TypeScript

2010-12-06 09:49:28

Linux快速啟動

2013-09-29 13:36:07

虛擬SAN

2019-11-12 14:50:49

Windows電腦Windows 10

2022-11-04 08:16:22

2023-12-04 14:28:15

模型應(yīng)用設(shè)計

2020-12-10 16:11:17

Java開發(fā)代碼

2025-02-03 00:10:00

人工智能DevOpsLLMOps

2021-05-12 09:00:00

WebReactJavaScript

2011-06-01 09:59:52

2022-10-19 15:20:58

pandas數(shù)據(jù)處理庫技巧

2024-01-03 08:53:35

JavaScrip編程語言NodeJS
點贊
收藏

51CTO技術(shù)棧公眾號