Java 工具和参数

1.常用命令行工具汇总

  • jps用于查看所有 Java 进程;
  • jstat用于收集 HotSpot 虚拟机各方面的运行数据;
  • jinfo显示JVM虚拟机各项信息;
  • jstack : Stack Trace for Java,生成虚拟机当前时刻的线程快照,线程快照就是当前虚拟机内每一条线程正在执行的方法堆栈的集合

 2. jps命令

【作用】jps ( JVMProcessStatus),用于查看所有 Java进程;

【示例 1】

jps 显示虚拟机执行主类名称以及这些进程的本地虚拟机唯一 IDLocal Virtual Machine Identifier,LVMID

         

【示例 2】

jps -l 输出主类的全名,如果进程执行的是 Jar 包,输出 Jar全名称

【示例 3】

jps -v 输出虚拟机进程启动时 JVM参数

 3. jstat命令

【作用】jstatJVM Statistics Monitoring Tool) 使用于监视虚拟机各种运行状态信息的命令行工具。 它可以显示本地或者远程(需要远程主机提供 RMI 支持)虚拟机进程中的类信息、内存、垃圾收集、JIT 编译等运行数据,在没有 GUI,只提供了纯文本控制台环境的服务器上,它将是运行期间定位虚拟机性能问题的首选工具。

【示例 1】

jstat -class -vmid 类加载统计

解析

  • Loaded:加载class的数量
  • Bytes:所占用空间大小
  • Unloaded:未加载数量
  • Bytes:未加载占用空间
  • Time:时间

【示例 2】

jstat -gc -vmid 垃圾回收统计

解析 

  • S0C:年轻代中第一个survivor(幸存区)的容量 (字节)
  • S1C:年轻代中第二个survivor(幸存区)的容量 (字节)
  • S0U :年轻代中第一个survivor(幸存区)目前已使用空间 (字节)
  • S1U :年轻代中第二个survivor(幸存区)目前已使用空间 (字节)
  • EC :年轻代中Eden区的容量 (字节)
  • EU :年轻代中Eden区目前已使用空间 (字节)
  • OC :老年代的容量 (字节)
  • OU :老年代目前已使用空间 (字节)
  • MCmetaspace(元空间)的容量 (字节)
  • MUmetaspace(元空间)目前已使用空间 (字节)
  • YGC :从应用程序启动到采样时年轻代中GC次数
  • YGCT:从应用程序启动到采样时年轻代中GC所用时间(s
  • FGC:从应用程序启动到采样时Full GC的次数
  • FGCT:从应用程序启动到采样时Full GC所用时间(s
  • GCT:从应用程序启动到采样时GC用的总时间(s

【示例 3】:

jstat -gccapacity -vmid 堆内存统计

解析

  • NGCMN :年轻代(young)中初始化(最小)的大小(字节)
  • NGCMX :年轻代(young)的最大容量(字节)
  • NGC :年轻代(young)中当前的容量(字节)
  • S0C :年轻代中第一个survivor(幸存区)的容量 (字节)
  • S1C : 年轻代中第二个survivor(幸存区)的容量(字节)
  • EC :年轻代中Eden区的容量(字节)
  • OGCMN :老年代中初始化(最小)的大小(字节)
  • OGCMX :老年代的最大容量(字节)
  • OGC:老年代当前新生成的容量 (字节)
  • OC :老年代的容量(字节)
  • MCMNmetaspace(元空间)中初始化(最小)的大小(字节)
  • MCMXmetaspace(元空间)的最大容量(字节)
  • MCmetaspace(元空间)当前新生成的容量(字节)
  • CCSMN:最小压缩类空间大小
  • CCSMX:最大压缩类空间大小
  • CCSC:当前压缩类空间大小
  • YGC :从应用程序启动到采样时年轻代中GC次数
  • FGC:从应用程序启动到采样时Full GC次数

【示例 4】

jstat -gcmetacapacity -vmid 元空间统计

解析 

  • MCMN:最小元数据容量
  • MCMX:最大元数据容量
  • MC:当前元数据空间大小
  • CCSMN:最小压缩类空间大小
  • CCSMX:最大压缩类空间大小
  • CCSC:当前压缩类空间大小
  • YGC :从应用程序启动到采样时年轻代中GC次数
  • FGC:从应用程序启动到采样时Full GC次数
  • FGCT:从应用程序启动到采样时Full GC所用时间(s
  • GCT:从应用程序启动到采样时GC用的总时间(s

【示例 5】:

jstat -gcnew -vmid 新生代统计

解析 

  • S0C :年轻代中第一个survivor(幸存区)的容量 (字节)
  • S1C :年轻代中第二个survivor(幸存区)的容量 (字节)
  • S0U :年轻代中第一个survivor(幸存区)目前已使用空间 (字节)
  • S1U :年轻代中第二个survivor(幸存区)目前已使用空间 (字节)
  • TT:持有次数限制
  • MTT:最大持有次数限制
  • DSS:期望的幸存区大小
  • EC:年轻代中Eden区的容量 (字节)
  • EU :年轻代中Eden区目前已使用空间 (字节)
  • YGC :从应用程序启动到采样时年轻代中GC次数
  • YGCT:从应用程序启动到采样时Full GC所用时间(s

【示例 6】:

jstat -gcold -vmid 老年代统计

解析 

  • MC metaspace(元空间)的容量 (字节)
  • MUmetaspace(元空间)目前已使用空间 (字节)
  • CCSC:压缩类空间大小
  • CCSU:压缩类空间使用大小
  • OCOld代的容量 (字节)
  • OUOld代目前已使用空间 (字节)
  • YGC:从应用程序启动到采样时年轻代中GC次数
  • FGC:从应用程序启动到采样时Full GC的次数
  • FGCT:从应用程序启动到采样时Full GC所用时间(s
  • GCT:从应用程序启动到采样时Full GC用的总时间(s)

【示例 7】

jstat -gcutil -vmid 老年代统计

解析

  • S0 :年轻代中第一个survivor(幸存区)已使用的占当前容量百分比
  • S1 :年轻代中第二个survivor(幸存区)已使用的占当前容量百分比
  • E :年轻代中Eden(伊甸园)已使用的占当前容量百分比
  • Oold代已使用的占当前容量百分比
  • Mmetaspace代已使用的占当前容量百分比
  • YGC :从应用程序启动到采样时年轻代中GC次数
  • YGCT:从应用程序启动到采样时年轻代中GC所用时间(s
  • FGC:从应用程序启动到采样时Full GC的次数
  • FGCT:从应用程序启动到采样时Full GC所用时间(s
  • GCT:从应用程序启动到采样时GC用的总时间(s

4. jinfo命令

【作用】:Configuration Info for Java,显示JVM虚拟机各项参数

【示例 1】:

jinfo vmid 输出当前 jvm进程的全部参数和系统属性,第一部分是系统属性,第二部分是 JVM参数。

C:\Users\lenovo>jinfo 82688
Attaching to process ID 82688, please wait...
Debugger attached successfully.
Server compiler detected.
JVM version is 25.152-b16
Java System Properties:

java.vendor = Oracle Corporation
preload.project.path = D:/idea-exe/ideaProject/java_jvm
sun.java.launcher = SUN_STANDARD
idea.config.path = C:\Users\lenovo\AppData\Roaming\JetBrains\IntelliJIdea2020.1
sun.management.compiler = HotSpot 64-Bit Tiered Compilers
sun.nio.ch.bugLevel =
idea.paths.selector = IntelliJIdea2020.1
kotlin.daemon.client.alive.path = "C:\Users\lenovo\AppData\Local\Temp\kotlin-idea-667098226065525183-is-running"
os.name = Windows 10
sun.boot.class.path = D:\javaMyEclipse-9.0M1\JDK1\jdk1.8.0_152\jre\lib\resources.jar;D:\javaMyEclipse-9.0M1\JDK1\jdk1.8.0_152\jre\lib\rt.jar;D:\javaMyEclipse-9.0M1\JDK1\jdk1.8.0_152\jre\lib\sunrsasign.jar;D:\javaMyEclipse-9.0M1\JDK1\jdk1.8.0_152\jre\lib\jsse.jar;D:\javaMyEclipse-9.0M1\JDK1\jdk1.8.0_152\jre\lib\jce.jar;D:\javaMyEclipse-9.0M1\JDK1\jdk1.8.0_152\jre\lib\charsets.jar;D:\javaMyEclipse-9.0M1\JDK1\jdk1.8.0_152\jre\lib\jfr.jar;D:\javaMyEclipse-9.0M1\JDK1\jdk1.8.0_152\jre\classes
sun.desktop = windows
idea.plugins.path = C:\Users\lenovo\AppData\Roaming\JetBrains\IntelliJIdea2020.1\plugins
java.vm.specification.vendor = Oracle Corporation
java.runtime.version = 1.8.0_152-b16
io.netty.serviceThreadPrefix = Netty
user.name = lenovo
kotlin.incremental.compilation = true
idea.home.path = D:\idea-exe\IntelliJ IDEA 2020.1.1
user.language = zh
jdt.compiler.useSingleThread = true
sun.boot.library.path = D:\javaMyEclipse-9.0M1\JDK1\jdk1.8.0_152\jre\bin
java.version = 1.8.0_152
user.timezone = Asia/Shanghai
kotlin.daemon.enabled =
sun.arch.data.model = 64
io.netty.initialSeedUniquifier = 3601004953466329236
java.endorsed.dirs = ""
java.rmi.server.randomIDs = true
sun.cpu.isalist = amd64
sun.jnu.encoding = GBK
file.encoding.pkg = sun.io
file.separator = \
java.specification.name = Java Platform API Specification
java.class.version = 52.0
user.country = CN
java.home = D:\javaMyEclipse-9.0M1\JDK1\jdk1.8.0_152\jre
java.vm.info = mixed mode
os.version = 10.0
path.separator = ;
java.vm.version = 25.152-b16
user.variant =
jps.fallback.jdk.version = 11.0.6
java.awt.printerjob = sun.awt.windows.WPrinterJob
sun.io.unicode.encoding = UnicodeLittle
awt.toolkit = sun.awt.windows.WToolkit
jps.log.dir = C:/Users/lenovo/AppData/Local/JetBrains/IntelliJIdea2020.1/log/build-log
io.netty.processId = 6597
user.script =
user.home = C:\Users\lenovo
java.specification.vendor = Oracle Corporation
java.library.path = D:\javaMyEclipse-9.0M1\JDK1\jdk1.8.0_152\bin;C:\WINDOWS\Sun\Java\bin;C:\WINDOWS\system32;C:\WINDOWS;D:\Linux\bin\;D:\javaMyEclipse-9.0M1\JDK1\jdk1.8.0_152\bin;C:\Program Files (x86)\Common Files\Oracle\Java\javapath;C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\System32\Wbem;C:\WINDOWS\System32\WindowsPowerShell\v1.0\;C:\WINDOWS\System32\OpenSSH\;D:\javaMyEclipse-9.0M1\JDK1\jdk1.8.0_152\jre\bin;D:\Hadoop\WinSCP\;D:\Hadoop\Xshell 7\;D:\Anacondadownload;D:\Anacondadownload\Scripts;D:\Anacondadownload\Library\bin;C:\Program Files\Microsoft SQL Server\150\Tools\Binn\;C:\Program Files\Microsoft SQL Server\Client SDK\ODBC\170\Tools\Binn\;C:\Program Files\dotnet\;D:\Softwares\gcc-linaro-5.5.0-2017.10-i686-mingw32_arm-linux-gnueabi\bin;D:\QT\Tools\mingw730_32\bin;D:\QT_QRS\ARMv7\bin;D:\mysql-8.0.33-winx64\bin;D:\apache-maven-3.8.6-bin\apache-maven-3.8.6\bin;D:\Git\Git\cmd;D:\RocketMQ\rocketmq-all-4.4.0-bin-release\bin;D:\Python\Scripts\;D:\Python\;D:\Python\python\Scripts\;D:\Python\python\;C:\Users\lenovo\AppData\Local\Microsoft\WindowsApps;C:\Users\lenovo\AppData\Local\Programs\Microsoft VS Code\bin;D:\Python\python\Scripts;C:\Users\lenovo\.dotnet\tools;D:\idea-exe\IntelliJ IDEA 2020.1.1\bin;;.
java.vendor.url = http://java.oracle.com/
jps.fallback.jdk.home = D:/idea-exe/IntelliJ IDEA 2020.1.1/jbr
java.vm.vendor = Oracle Corporation
java.runtime.name = Java(TM) SE Runtime Environment
sun.java.command = org.jetbrains.jps.cmdline.Launcher D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/maven-artifact-3.6.1.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/java/lib/maven-resolver-transport-file-1.3.3.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/plexus-interpolation-1.25.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/asm-all-7.0.1.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/log4j.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/java/lib/maven-resolver-connector-basic-1.3.3.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/trove4j.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/protobuf-java-3.5.1.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/jna-platform.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/lz4-java-1.7.1.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/slf4j-api-1.7.25.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/nanoxml-2.2.3.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/gson-2.8.6.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/platform-api.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/jdom.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/netty-common-4.1.47.Final.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/oro-2.0.8.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/maven-resolver-spi-1.3.3.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/plexus-component-annotations-1.7.1.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/commons-lang3-3.9.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/maven-resolver-provider-3.6.1.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/resources_en.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/commons-logging-1.2.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/jps-model.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/netty-resolver-4.1.47.Final.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/maven-model-3.6.1.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/qdox-2.0-M10.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/java/lib/jps-builders.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/guava-28.2-jre.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/forms-1.1-preview.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/maven-repository-metadata-3.6.1.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/plexus-utils-3.2.0.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/java/lib/maven-resolver-transport-http-1.3.3.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/maven-resolver-impl-1.3.3.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/netty-transport-4.1.47.Final.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/util.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/jna.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/httpcore-4.4.13.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/netty-codec-4.1.47.Final.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/maven-resolver-util-1.3.3.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/maven-resolver-api-1.3.3.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/httpclient-4.5.12.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/annotations.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/java/lib/aether-dependency-resolver.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/maven-builder-support-3.6.1.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/netty-buffer-4.1.47.Final.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/java/lib/javac2.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/idea_rt.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/java/lib/jps-builders-6.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/maven-model-builder-3.6.1.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/JavaEE/lib/jasper-v2-rt.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/gson-2.8.6.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/android/lib/jarutils.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/guava-28.2-jre.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/android/lib/common-26.6.0.2.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/gradle/lib/gradle-api-6.1.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/gson-2.8.6.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/android/lib/jarutils.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/lib/guava-28.2-jre.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/android/lib/common-26.6.0.2.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/gradle/lib/gradle-api-6.1.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/IntelliLang/lib/intellilang-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/eclipse/lib/eclipse-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/eclipse/lib/common-eclipse-util.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/ant/lib/ant-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/Groovy/lib/groovy-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/Groovy/lib/groovy-rt-constants.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/maven/lib/maven-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/osmorc/lib/osmorc-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/osmorc/lib/biz.aQute.bndlib-5.0.0.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/osmorc/lib/biz.aQute.repository-5.0.0.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/osmorc/lib/biz.aQute.resolve-5.0.0.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/osmorc/lib/bundlor-all.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/aspectj/lib/aspectj-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/gradle-java/lib/gradle-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/javaFX/lib/javaFX-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/javaFX/lib/common-javaFX-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/uiDesigner/lib/jps/ui-designer-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/devkit/lib/devkit-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/flex/lib/flex-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/flex/lib/flex-shared.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/JavaEE/lib/javaee-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/JavaEE/lib/jps/jpa-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/Kotlin/lib/jps/kotlin-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/Kotlin/lib/kotlin-stdlib.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/Kotlin/lib/kotlin-reflect.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/Kotlin/lib/kotlin-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/android/lib/jps/android-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/android/lib/android-common.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/android/lib/build-common.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/android/lib/android-rt.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/android/lib/android-extensions-ide.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/android/lib/sdk-common-26.6.0.2.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/android/lib/common-26.6.0.2.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/android/lib/repository-26.6.0.2.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/android/lib/sdklib-26.6.0.2.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/android/lib/jarutils.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/android/lib/layoutlib-api-26.6.0.2.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/android/lib/manifest-merger-26.6.0.2.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/webSphereIntegration/lib/jps/webSphere-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/weblogicIntegration/lib/jps/weblogic-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/dmServer/lib/dmServer-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/GwtStudio/lib/gwt-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/Grails/lib/grails-jps-plugin.jar;D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/Grails/lib/grails-compiler-patch.jar org.jetbrains.jps.cmdline.BuildMain 127.0.0.1 60395 5b41d92d-3fdb-4f67-b21a-f679ef466e4e C:/Users/lenovo/AppData/Local/JetBrains/IntelliJIdea2020.1/compile-server
java.class.path = D:/idea-exe/IntelliJ IDEA 2020.1.1/plugins/java/lib/jps-launcher.jar;D:/javaMyEclipse-9.0M1/JDK1/jdk1.8.0_152/lib/tools.jar
io.netty.machineId = 28:f0:76:ff:fe:16:65:0e
java.vm.specification.name = Java Virtual Machine Specification
jps.backward.ref.index.builder = true
java.vm.specification.version = 1.8
preload.config.path = C:/Users/lenovo/AppData/Roaming/JetBrains/IntelliJIdea2020.1/options
sun.cpu.endian = little
sun.os.patch.level =
java.awt.headless = true
java.io.tmpdir = C:/Users/lenovo/AppData/Local/JetBrains/IntelliJIdea2020.1/compile-server/java_jvm_a9dce781/_temp_
java.vendor.url.bug = http://bugreport.sun.com/bugreport/
os.arch = amd64
java.awt.graphicsenv = sun.awt.Win32GraphicsEnvironment
java.ext.dirs = D:\javaMyEclipse-9.0M1\JDK1\jdk1.8.0_152\jre\lib\ext;C:\WINDOWS\Sun\Java\lib\ext
rebuild.on.dependency.change = true
user.dir = C:\Users\lenovo\AppData\Local\JetBrains\IntelliJIdea2020.1\compile-server
line.separator =

java.vm.name = Java HotSpot(TM) 64-Bit Server VM
file.encoding = GBK
java.specification.version = 1.8
kotlin.incremental.compilation.js = true
compile.parallel = false
io.netty.noUnsafe = true

VM Flags:
Non-default VM flags: -XX:CICompilerCount=4 -XX:InitialHeapSize=257949696 -XX:MaxHeapSize=734003200 -XX:MaxNewSize=244318208 -XX:MinHeapDeltaBytes=524288 -XX:NewSize=85983232 -XX:OldSize=171966464 -XX:+UseCompressedClassPointers -XX:+UseCompressedOops -XX:+UseFastUnorderedTimeStamps -XX:-UseLargePagesIndividualAllocation -XX:+UseParallelGC
Command line:  -Xmx700m -Djava.awt.headless=true -Djava.endorsed.dirs="" -Djdt.compiler.useSingleThread=true -Dpreload.project.path=D:/idea-exe/ideaProject/java_jvm -Dpreload.config.path=C:/Users/lenovo/AppData/Roaming/JetBrains/IntelliJIdea2020.1/options -Dcompile.parallel=false -Drebuild.on.dependency.change=true -Dio.netty.initialSeedUniquifier=3601004953466329236 -Dfile.encoding=GBK -Duser.language=zh -Duser.country=CN -Didea.paths.selector=IntelliJIdea2020.1 -Didea.home.path=D:\idea-exe\IntelliJ IDEA 2020.1.1 -Didea.config.path=C:\Users\lenovo\AppData\Roaming\JetBrains\IntelliJIdea2020.1 -Didea.plugins.path=C:\Users\lenovo\AppData\Roaming\JetBrains\IntelliJIdea2020.1\plugins -Djps.log.dir=C:/Users/lenovo/AppData/Local/JetBrains/IntelliJIdea2020.1/log/build-log -Djps.fallback.jdk.home=D:/idea-exe/IntelliJ IDEA 2020.1.1/jbr -Djps.fallback.jdk.version=11.0.6 -Dio.netty.noUnsafe=true -Djava.io.tmpdir=C:/Users/lenovo/AppData/Local/JetBrains/IntelliJIdea2020.1/compile-server/java_jvm_a9dce781/_temp_ -Djps.backward.ref.index.builder=true -Dkotlin.incremental.compilation=true -Dkotlin.incremental.compilation.js=true -Dkotlin.daemon.enabled -Dkotlin.daemon.client.alive.path="C:\Users\lenovo\AppData\Local\Temp\kotlin-idea-667098226065525183-is-running"

【示例 2】:

jinfo -flags vmid 输出全部JVM参数

C:\Users\lenovo>jinfo -flags 82688
Attaching to process ID 82688, please wait...
Debugger attached successfully.
Server compiler detected.
JVM version is 25.152-b16
Non-default VM flags: -XX:CICompilerCount=4 -XX:InitialHeapSize=257949696 -XX:MaxHeapSize=734003200 -XX:MaxNewSize=244318208 -XX:MinHeapDeltaBytes=524288 -XX:NewSize=85983232 -XX:OldSize=171966464 -XX:+UseCompressedClassPointers -XX:+UseCompressedOops -XX:+UseFastUnorderedTimeStamps -XX:-UseLargePagesIndividualAllocation -XX:+UseParallelGC
Command line:  -Xmx700m -Djava.awt.headless=true -Djava.endorsed.dirs="" -Djdt.compiler.useSingleThread=true -Dpreload.project.path=D:/idea-exe/ideaProject/java_jvm -Dpreload.config.path=C:/Users/lenovo/AppData/Roaming/JetBrains/IntelliJIdea2020.1/options -Dcompile.parallel=false -Drebuild.on.dependency.change=true -Dio.netty.initialSeedUniquifier=3601004953466329236 -Dfile.encoding=GBK -Duser.language=zh -Duser.country=CN -Didea.paths.selector=IntelliJIdea2020.1 -Didea.home.path=D:\idea-exe\IntelliJ IDEA 2020.1.1 -Didea.config.path=C:\Users\lenovo\AppData\Roaming\JetBrains\IntelliJIdea2020.1 -Didea.plugins.path=C:\Users\lenovo\AppData\Roaming\JetBrains\IntelliJIdea2020.1\plugins -Djps.log.dir=C:/Users/lenovo/AppData/Local/JetBrains/IntelliJIdea2020.1/log/build-log -Djps.fallback.jdk.home=D:/idea-exe/IntelliJ IDEA 2020.1.1/jbr -Djps.fallback.jdk.version=11.0.6 -Dio.netty.noUnsafe=true -Djava.io.tmpdir=C:/Users/lenovo/AppData/Local/JetBrains/IntelliJIdea2020.1/compile-server/java_jvm_a9dce781/_temp_ -Djps.backward.ref.index.builder=true -Dkotlin.incremental.compilation=true -Dkotlin.incremental.compilation.js=true -Dkotlin.daemon.enabled -Dkotlin.daemon.client.alive.path="C:\Users\lenovo\AppData\Local\Temp\kotlin-idea-667098226065525183-is-running"

【示例 3】:

jinfo -flag InitialHeapSize vmid 查看堆的初始容量

【示例 4】:

jinfo -flag PrintGC vmid 查看是否开启GC日志,如果没有打开,则输出:-XX:-PrintGC。使用+PrintGC开启

5. jstack命令重要

【作用】Stack Trace for Java,用于生成虚拟机当前时刻的线程快照。线程快照就是当前虚拟机内每一条线程正在执行的方法堆栈的集合信息。生成线程快照的目的主要是定位线程长时间出现停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间等待等都是导致线程长时间停顿的原因。线程出现停顿的时候通过jstack来查看各个线程的调用堆栈,就可以知道没有响应的线程到底在后台做些什么事情,或者在等待些什么资源。

【线程死锁案例】

public class DeadLockDemo {
    private static Object objLock1 = new Object();	// 对象锁1
    private static Object objLock2 = new Object();	// 对象锁2

    public static void main(String[] args) {

        // 线程1
        new Thread(() -> {
            synchronized (objLock1) {
                System.out.println(Thread.currentThread().getName() + "获取对象锁1");
                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }

                System.out.println(Thread.currentThread().getName() + "等待获取对象锁2");
                synchronized (objLock2) {
                    System.out.println(Thread.currentThread().getName() + "获取对象锁2");
                }
            }
        }, "线程 1").start();

        // 线程2
        new Thread(() -> {
            synchronized (objLock2) {
                System.out.println(Thread.currentThread().getName() + "获取对象锁2");
                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }

                System.out.println(Thread.currentThread().getName() + "等待获取对象锁1");
                synchronized (objLock1) {
                    System.out.println(Thread.currentThread().getName() + "获取对象锁1");
                }
            }
        }, "线程 2").start();
    }
}

输出:出现死锁

线程 1 通过 synchronized (objLock1) 获得 objLock1 的监视器锁,然后通过 Thread.sleep(1000); 让线程 1 休眠 1s ,目的是让线程 B 得到执行然后获取到 objLock2的监视器锁。线程 1 和线程 2 休眠结束了都开始企图请求获取对方的对象锁,然后这两个线程就会陷入互相等待的状态,这也就产生了死锁。

 【实时分析】:

jstack vmid 用于生成虚拟机当前时刻的线程快照

 6. 用可视化工具

jvisualvm

jmc

7.常用JVM运行参数 

7.1. 标准参数选项

C:\Users\lenovo>java -help
用法: java [-options] class [args...]
           (执行类)
   或  java [-options] -jar jarfile [args...]
           (执行 jar 文件)
其中选项包括:
    -d32          使用 32 位数据模型 (如果可用)
    -d64          使用 64 位数据模型 (如果可用)
    -server       选择 "server" VM
                  默认 VM 是 server.

    -cp <目录和 zip/jar 文件的类搜索路径>
    -classpath <目录和 zip/jar 文件的类搜索路径>
                  用 ; 分隔的目录, JAR 档案
                  和 ZIP 档案列表, 用于搜索类文件。
    -D<名称>=<值>
                  设置系统属性
    -verbose:[class|gc|jni]
                  启用详细输出
    -version      输出产品版本并退出
    -version:<值>
                  警告: 此功能已过时, 将在
                  未来发行版中删除。
                  需要指定的版本才能运行
    -showversion  输出产品版本并继续
    -jre-restrict-search | -no-jre-restrict-search
                  警告: 此功能已过时, 将在
                  未来发行版中删除。
                  在版本搜索中包括/排除用户专用 JRE
    -? -help      输出此帮助消息
    -X            输出非标准选项的帮助
    -ea[:<packagename>...|:<classname>]
    -enableassertions[:<packagename>...|:<classname>]
                  按指定的粒度启用断言
    -da[:<packagename>...|:<classname>]
    -disableassertions[:<packagename>...|:<classname>]
                  禁用具有指定粒度的断言
    -esa | -enablesystemassertions
                  启用系统断言
    -dsa | -disablesystemassertions
                  禁用系统断言
    -agentlib:<libname>[=<选项>]
                  加载本机代理库 <libname>, 例如 -agentlib:hprof
                  另请参阅 -agentlib:jdwp=help 和 -agentlib:hprof=help
    -agentpath:<pathname>[=<选项>]
                  按完整路径名加载本机代理库
    -javaagent:<jarpath>[=<选项>]
                  加载 Java 编程语言代理, 请参阅 java.lang.instrument
    -splash:<imagepath>
                  使用指定的图像显示启动屏幕
有关详细信息, 请参阅 http://www.oracle.com/technetwork/java/javase/documentation/index.html。

-server 和 -client 参数

Hotspot JVM有两种模式,分别是serverclient,分别通过-server-client模式设置

  • 32位系统上,默认使用Client类型的JVM
    • Server模式,机器配置至少有2个以上的CPU2G以上的物理内存。
    • client模式适用于对内存要求较小的桌面应用程序,默认使用Serial串行垃圾收集器。
  • 64位系统上,只支持server模式的JVM,适用于需要大内存的应用程序,默认使用并行垃圾收集器。

 7.2. X参数选项

C:\Users\lenovo>java -X
    -Xmixed           混合模式执行 (默认)
    -Xint             仅解释模式执行
    -Xbootclasspath:<用 ; 分隔的目录和 zip/jar 文件>
                      设置搜索路径以引导类和资源
    -Xbootclasspath/a:<用 ; 分隔的目录和 zip/jar 文件>
                      附加在引导类路径末尾
    -Xbootclasspath/p:<用 ; 分隔的目录和 zip/jar 文件>
                      置于引导类路径之前
    -Xdiag            显示附加诊断消息
    -Xnoclassgc       禁用类垃圾收集
    -Xincgc           启用增量垃圾收集
    -Xloggc:<file>    将 GC 状态记录在文件中 (带时间戳)
    -Xbatch           禁用后台编译
    -Xms<size>        设置初始 Java 堆大小
    -Xmx<size>        设置最大 Java 堆大小
    -Xss<size>        设置 Java 线程堆栈大小
    -Xprof            输出 cpu 配置文件数据
    -Xfuture          启用最严格的检查, 预期将来的默认值
    -Xrs              减少 Java/VM 对操作系统信号的使用 (请参阅文档)
    -Xcheck:jni       对 JNI 函数执行其他检查
    -Xshare:off       不尝试使用共享类数据
    -Xshare:auto      在可能的情况下使用共享类数据 (默认)
    -Xshare:on        要求使用共享类数据, 否则将失败。
    -XshowSettings    显示所有设置并继续
    -XshowSettings:all
                      显示所有设置并继续
    -XshowSettings:vm 显示所有与 vm 相关的设置并继续
    -XshowSettings:properties
                      显示所有属性设置并继续
    -XshowSettings:locale
                      显示所有与区域设置相关的设置并继续

-X 选项是非标准选项, 如有更改, 恕不另行通知。

参数名称

含义

默认值

-Xms

初始堆大小

物理内存的1/64(<1GB)

当空闲堆内存小于40%时,代表堆内存不足,则JVM就会增大堆内存,

直到-Xmx的最大限制.

-Xmx

最大堆大小

物理内存的1/4(<1GB)

当空闲堆内存大于70%时,代表堆内存闲置太多,存在不必要的内存开销。则JVM会减少堆内存,

直到-Xms的最小限制

-Xmn

新生代大小

新生代的内存容量 = Eden+ Survivor * 2

-Xss

每个线程的虚拟机栈大小

JDK5.0以后每个线程虚拟机栈大小为1M,以前每个线程虚拟机栈大小为256K.

-XX:NewRatio

新生代与老年代的比值

-XX:NewRatio=4表示年轻代与年老代所占比值为1:4,年轻代占整个堆栈的1/5

-XX:SurvivorRatio

Eden区与Survivor区的大小比值

默认值为8

则两个Survivor区与一个Eden区的比值为2:8,

一个Survivor区占整个年轻代的1/10

-XX:ParallelGCThreads

并行收集器的线程数

7.3. XX参数选项

7.3.1. Boolean类型格式

-XX:+<option>  启用option属性
-XX:-<option>  禁用option属性

7.3.2. 键值对类型格式

-XX:<option>=<number>  设置option数值,可以带单位如k/K/m/M/g/G
-XX:<option>=<string>  设置option字符值

7.4. 案例【设置JVM参数】

java -Xms100m -Xmx100m -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintGCTimeStamps -XX:+PrintHeapAtGC -jar visualization.jar
  • -XX:+PrintGC 输出GC日志
  • -XX:+PrintGCDetails 输出GC的详细日志
  • -XX:+PrintGCTimeStamps 输出GC的时间戳(以基准时间的形式)
  • -XX:+PrintGCDateStamps 输出GC的时间戳(以日期的形式,如 2017-09-04T21:53:59.234+0800)
  • -XX:+PrintHeapAtGC 在进行GC的前后打印出堆的信息 

下载visualization.jar地址:

百度网盘 请输入提取码 

提取码:btt1 

7.5GC日志阅读

7.5.1GC日志分类

Young GC回收日志:

[GC (Allocation Failure) [PSYoungGen: 637744K->43513K(620544K)] 714874K->144918K(730624K), 0.0652514 secs] [Times: user=0.20 sys=0.05, real=0.07 secs]


Full GC回收日志:

[Full GC (Ergonomics) [PSYoungGen: 43513K->23126K(620544K)] [ParOldGen: 101404K->109897K(221184K)] 144918K->133024K(841728K), [Metaspace: 77276K->76763K(1120256K)], 0.3217926 secs] [Times: user=1.55 sys=0.06, real=0.32 secs]


7.5.2GC日志结构剖析

透过日志看垃圾收集器
● Serial收集器:新生代显示 "[DefNew",即 Default New Generation
● ParNew收集器:新生代显示 "[ParNew",即 Parallel New Generation
● Parallel Scavenge收集器:新生代显示"[PSYoungGen",JDK1.7使用的即PSYoungGen
● Parallel Old收集器:老年代显示"[ParoldGen"
● G1收集器:显示”garbage-first heap“


透过日志看GC原因
●Allocation Failure:表明本次引起GC的原因是因为新生代中没有足够的区域存放需要分配的数据
●Metadata GCThreshold:Metaspace区不够用了
●FErgonomics:JVM自适应调整导致的GC
●System:调用了System.gc()方法


透过日志看GC前后情况
GC日志格式的规律一般都是:GC前内存占用->GC后内存占用(该区域内存总大小):
[PSYoungGen: 5986K->696K (8704K) ] 5986K->704K (9216K)
●中括号内:GC回收前年轻代堆大小,回收后大小,(年轻代堆总大小)
● 括号外:GC回收前年轻代和老年代大小,回收后大小,(年轻代和老年代总大小)
注意:Minor GC堆内存总容量 = 9/10 年轻代 + 老年代。原因是Survivor区只计算from部分,而JVM默认年轻代中Eden区和Survivor区的比例关系,Eden:S0:S1=8:1:1。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值