秒懂JVM的三大参数类型,就靠这十个小实验了

云计算 虚拟化
本实验的目的是讲解 JVM 的三大参数类型。在JVM调优中用到的最多的 XX 参数,而如何去查看和设置 JVM 的 XX 参数也是调优的基本功,本节以实验的方式讲解 JVM 参数的查看和设置。希望大家能有所启发。

[[343690]]

作者 | 悟空哥

来源 | 悟空聊架构(ID:PassJava666)

本实验的目的是讲解 JVM 的三大参数类型。在JVM调优中用到的最多的 XX 参数,而如何去查看和设置 JVM 的 XX 参数也是调优的基本功,本节以实验的方式讲解 JVM 参数的查看和设置。希望大家能有所启发。

 

标配参数

常见标配参数

  • -version,获取JDK版本
  • -help,获取帮助
  • -showverision,获取JDK版本和帮助

动手实验 1 - 查看标配参数

实验步骤:

查看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 参数

X 参数简介

我们常用的javac大家都知道是把java代码编译成 class 文 Java 文件,那么 class 文件怎么去执行呢?这里用到了三个X参数来说明 class 文件怎么在虚拟机里面跑起来的。

  • -Xint:直接解释执行
  • -Xcomp:先编译成本地代码再执行
  • -XMixed:混合模式(既有编译执行也有解释执行)

动手实验 2 - 查看和配置X参数

查看版本

  1. java -version 

在WebIDE的控制台窗口执行Java -version 后,可以看到我的环境是混合模式执行java程序的。

实验 2-1

 

  • 修改编译模式为解释执行模式
  1. java -Xint -version 

在WebIDE的控制台窗口执行命令

实验 2-2

 

  • 修改编译模式为只编译模式
  1. java -Xcomp -version 

实验 2-3

 

XX 参数

XX 参数简介

XX 参数有两种类型,一种是 Boolean 类型,另外一种是键值对类型。

  • Boolean 类型
    • 公式:-XX:+某个属性 或者,-XX:-某个属性 +表示开启了这个属性,-表示关闭了这个属性。
    • 案例:-XX:-PrintGCDetails,表示关闭了GC详情输出
  • key-value类型
    • 公式:-XX:属性key=属性value
    • 案例:-XX:属性metaspace=2000000,设置Java元空间的值为2000000。

动手实验 3 - 查看参数是否开启

本实验主要讲解如下内容:查看运行的 Java 程序 PrintGCDetails 参数是否开启

  • 编写一个一直运行的 Java 程序
  • 查看该应用程序的进程 id
  • 查看该进程的 GCDetail 参数是否开启

在 WebIDE 上右键单击菜单,选择 New File 创建新文件

New File

 

创建文件名为 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  

编译代码

 

编译之后,会在当前文件夹产生我们所编写的 demoXXparam 类的 demoXXparam.class 字节码文件

生产Class文件

 

在 WebIDE 上运行 demoXXparam 代码

  1. java demoXXparam 

运行Java程序

 

输出:

  1. hello XX params 

在 WebIDE 中新开一个控制台窗口

Terminal->New Terminal

开启新控制台窗口

 

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

  1. jps -l 

jps

 

发现demoXXparam进程的id为 518

查看 demoXXparam 程序是否开启了PrintGCDetails这个参数

PrintGCDetails: 在发生垃圾回收时打印内存回收日志,并在进程退出时输出当前内存各区域分配情况

  1. jinfo -flag PrintGCDetails 518 

jinfo

 

结果如下:

  1. -XX:-PrintGCDetails 

上面提到 -号表示关闭,所以当前 demo 程序没有开启 PrintGCDetails参数。

动手实验 4 - 开启参数

  • 在 WebIDE 控制台强制退出demoXXparam程序
  1. ctrl + c 
  • 然后清理屏幕
  1. clear 
  • 然后以参数 -XX:+PrintGCDetails 运行 demoXXparam 程序
  1. java -XX:+PrintGCDetails demoXXparam 

实验 4

 

  • 输出:
  1. hello XX params 

查看demoXXparam进程的 id

进程 id

 

可以看到demoXXparam进程 id 为 1225

查看 demoXXparam 的配置参数 PrintGCDetails

打开一个新的控制台窗口,执行以下命令来查看进程为 1225 的 PrintGCDetails参数是否开启

  1. jinfo -flag PrintGCDetails 1225 

PrintGCDetails 参数

 

可以看到PrintGCDetails是开启的,+号表示开启。

动手实验 5 - Key-Value 类型参数值

查看元空间的值

  1. jinfo -flag MetaspaceSize 526 

MetaspaceSize 大小

 

由此可以得出元空间的大小为 21 M。

设置元空间的值为 128 M

  1. java -XX:MetaspaceSize=128m demoXXparam    

查看元空间的大小

  1. jinfo -flag MetaspaceSize 1062 

调整元空间大小

 

最常见的 -Xms 和 -Xmx 属于哪种参数?

  • -Xms参数代表-XX:InitialHeapSize ,初始化堆内存(默认只会用最大物理内存的64分1)
  • -Xmx:参数代表-XX:MaxHeapSize ,大堆内存(默认只会用最大物理内存的4分1)

起了别名,但还是属于XX参数。

动手实验 6 - 设置 -XX:InitialHeapSize 和 -XX:MaxHeapSize 的值。

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

查看 InitialHeapSize 参数的值,大小为 200 M。

设置 InitialHeapSize

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

查看 MaxHeapSize 参数的值,大小为 200 M。

 


设置 MaxHeapSize

 

 

扩展:查看 Java 程序已设置的所有参数值

  1. jinfo -flags <进程id> 

 


mark

 

 

  • Non-Defalut VM flags 代表参数类型是JVM自带的参数。
  • Command line 代表是用户自定义的参数

如何查看出厂设置和自定义设置的XX配置项动手实验

7 - 查看出厂默认设置的所有XX配置项

  1. java -XX:+PrintFlagsInitial -version  

 

 


PrintFlagsInitial

 

 

动手实验 8 - 查看 JVM 当前所有XX配置项

  1. java -XX:+PrintFlagsFinal -version 

 

 


PrintFlagsFinal

 

 

我们可以看到几个关键信息:

  • [Global flags]:全局参数,如果自定义修改了某个应用的参数,并不会修改全局参数

比如之前我们修改了MetaspaceSize为128m,但列表里面还是21m。

 

 


Global flags

 

 

  • :=:参数已被修改,如下图所示InitialHeapSize初始化堆内存参数已修改为264241152

总结如下:

 

 


出厂设置和自定义参数设置

 

 

动手实验 9 - 运行程序时打印XX配置选项

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

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

运行程序时打印XX配置选项

 

动手实验 10 - 查看 JVM 自动配置的或者用户手动设置的XX选项(非应用程序的)

  1. java -XX:+PrintCommandLineFlags -version 

会打印出如下参数:

 


JVM 自动配置的XX选项

 

 

实验总结

本节实验课学习了如何查看基本参数、X参数、XX参数和设置XX参数。以及用好jps和jinfo工具来查看进程和设置参数。

JVM性能调优还有很多要讲的,一篇是讲不完的,我会分成几篇来为大家讲述,形式主要以小实验的方式来为大家讲解。

本文转载自微信公众号「 悟空聊架构」,可以通过以下二维码关注。转载本文请联系 悟空聊架构公众号。

 

 

责任编辑:武晓燕 来源: 悟空聊架构
相关推荐

2017-05-10 11:08:59

2018-02-02 10:49:05

编程开发Java

2020-07-29 15:01:50

JVMGCJDK

2020-10-14 15:00:38

Python 开发编程语言

2024-01-30 00:40:10

2021-04-16 08:11:07

程序体积优化

2013-09-29 13:36:07

虚拟SAN

2010-12-06 09:49:28

Linux快速启动

2021-10-18 08:01:44

TS语言TypeScript

2024-04-29 08:35:29

监控Kafka集群

2019-11-12 14:50:49

Windows电脑Windows 10

2020-12-10 16:11:17

Java开发代码

2022-11-04 08:16:22

2023-12-04 14:28:15

模型应用设计

2021-05-12 09:00:00

WebReactJavaScript

2011-06-01 09:59:52

2022-10-19 15:20:58

pandas数据处理库技巧

2024-01-03 08:53:35

JavaScrip编程语言NodeJS

2023-11-08 18:05:06

Python类型技巧

2023-05-15 12:11:24

点赞
收藏

51CTO技术栈公众号