JDK常用命令jps jinfo jstat的具體說明與示例
概述
JDK的bin目錄下提供了很多命令工具,比如java.exe,javap.exe,javac.exe。。。。。。這些命令由jdk/lib/tools.jar類庫中提供的,是對tools.jar中的類的封裝。我們主要介紹一下JVM中處理運行日志、異常堆棧、GC日志、線程快照(threaddump / javacore文件)、堆轉(zhuǎn)儲快照(heapdump/hprof文件)等信息的相關(guān)常用命令(jhat就不再介紹了,用的比較少,目前都是用jmap+MAT分別進行生產(chǎn)heapdump文件的生成及分析),這些常用命令在JDK8中的官方文檔地址為https://docs.oracle.com/javase/8/docs/technotes/tools/unix/index.html,打開官方文檔地址可以看到如下所示,我們所介紹的命令里面都有說明,可以對應(yīng)著看一下。
常用命令介紹: 本節(jié)先介紹前三個,下面的后面進行介紹。
名稱 | 主要功能 |
jps | JVM Process Status Tool,顯示指定系統(tǒng)內(nèi)所有HotSpot虛擬機進程 |
jstat | JVM Statistics Minitoring Tool,用于收集HotSpot虛擬機各方面的運行數(shù)據(jù) |
jinfo | Configuration Info for Java,顯示虛擬機配置信息 |
jmap | Memory Map for Java,生成虛擬機的內(nèi)存轉(zhuǎn)儲快照(heapdump)文件 |
jhat | JVM Heap Dump Browser,用于分析heapdump文件,它會建立一個HTTP/HTML服務(wù)器,讓用戶可以在瀏覽器上查看分析結(jié)果 |
jstack | Stack Trace for Java,顯示虛擬機的線程快照 |
注意:我演示使用的是JDK1.8
jps:虛擬機進程狀況工具
jps(JVM Process Status Tool):可以列出正在運行的虛擬機進程,并顯示虛擬機執(zhí)行主類(Main Class,main()函數(shù)所在的類)的名稱,以及這些進程的本地虛擬機的唯一ID(LVMID,Local Virtual Machine Identifier)。對于本地虛擬機進程來說,LVMID與操作系統(tǒng)的進程ID(PID,Process Identifier)是一致的,在Linux上使用ps命令也可以查看進程ID(例如 ps -ef | grep java 查看Java進程)。官方文檔地址:https://docs.oracle.com/javase/8/docs/technotes/tools/unix/jps.html
通過 jps -help 命令可以查看jps命令的使用說明
C:\Users\Administrator>jps -help usage: jps [-help] jps [-q] [-mlvV] [<hostid>] Definitions: <hostid>: <hostname>[:<port>]
可以看到j(luò)ps命令格式:jps [option] [hostid]
jps除了查詢本地Java進程,還可以通過RMI協(xié)議查詢開啟了RMI服務(wù)的遠程虛擬機進程狀態(tài),hostid為RMI注冊表中注冊的主機名。jps的常用選項如下:
選項 | 作用 |
-q | 只輸出LVMID,省略主類的名稱 |
-m | 輸出虛擬機進程啟動時傳遞給主類的main()函數(shù)的參數(shù) |
-l | 輸出主類的全名,如果進程執(zhí)行的是jar包,輸出jar路徑 |
-v | 輸出虛擬機進程啟動時JVM參數(shù) |
使用示例:
C:\Users\Administrator>jps -l 13120 sun.tools.jps.Jps 11332 14284 com.wkp.demo.ServiceapiApplication 6908 6924
jinfo:Java配置信息工具
jinfo(Configuration Info for Java)的作用是實時地查看和調(diào)整虛擬機的各項參數(shù)。官方文檔地址為:https://docs.oracle.com/javase/8/docs/technotes/tools/unix/jinfo.html
通過 jinfo -help 命令可以查看jinfo命令的使用信息:其使用格式為 jinfo [option] pid
C:\Users\Administrator>jinfo -help Usage: jinfo [option] <pid> (to connect to running process) jinfo [option] <executable <core> (to connect to a core file) jinfo [option] [server_id@]<remote server IP or hostname> (to connect to remote debug server) where <option> is one of: -flag <name> to print the value of the named VM flag -flag [+|-]<name> to enable or disable the named VM flag -flag <name>=<value> to set the named VM flag to the given value -flags to print VM flags -sysprops to print Java system properties <no option> to print both of the above -h | -help to print this help message
jinfo命令選項介紹:
選項 | 作用 |
-flag | 查看JVM參數(shù)選項值(如果沒有設(shè)置過會打印默認值,使用java -XX:+PrintFlagsFinal也可以查看參數(shù)默認值) |
-flag [+|-]<name> | 程序運行時啟用/禁用JVM的Boolean類型參數(shù)選項 |
-flag <name>=<value | 程序運行時設(shè)置JVM的非Boolean類型參數(shù)選項值 |
-flags | 打印設(shè)置的JVM參數(shù)選項 |
-sysprops | 把虛擬機進程的System.getProperties()的內(nèi)容打印出來 |
<no option> | 不寫option的話會打印上面的所有信息 |
使用示例:
C:\Users\Administrator>jinfo -flag MaxHeapSize 14284 -XX:MaxHeapSize=67108864
C:\Users\Administrator>jinfo -flags 14284 Attaching to process ID 14284, please wait... Debugger attached successfully. Server compiler detected. JVM version is 25.112-b15 Non-default VM flags: -XX:CICompilerCount=3 -XX:InitialHeapSize=8388608 -XX:+ManagementServer -XX:MaxHeapSize=67108864 -XX:MaxNewSize=22347776 -XX:MaxTenuringThreshold=6 -XX:MinHeapDeltaBytes=196608 - XX:NewSize=2752512 -XX:OldPLABSize=16 -XX:OldSize=5636096 -XX:+PrintCommandLineFlags -XX:+PrintFlagsFinal -XX:+PrintGC -XX:+PrintGCApplicationStoppedTime -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX :+PrintHeapAtGC -XX:+UseCompressedClassPointers -XX:+UseCompressedOops -XX:+UseConcMarkSweepGC -XX:+UseFastUnorderedTimeStamps -XX:-UseLargePagesIndividualAllocation -XX:+UseParNewGC Command line: -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=63038 -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -Dspring.liveBeansVie w.mbeanDomain -Dspring.application.admin.enabled=true -Xms8m -Xmx64m -verbose:gc -Xloggc:D:\workspaces\hgwd-Wp\logs\hgwd-usercenter\gc.log -XX:+PrintHeapAtGC -XX:+PrintGCApplicationStoppedTime -XX:+Pr intGCTimeStamps -XX:+PrintCommandLineFlags -XX:+PrintFlagsFinal -XX:+PrintGCDetails -XX:+UseConcMarkSweepGC -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false - Dcom.sun.management.jmxremote.port=9004 -Djava.rmi.server.hostname=127.0.0.1 -Dfile.encoding=UTF-8
jstat:虛擬機統(tǒng)計信息監(jiān)控工具
jstat(JVM Statistics Monitoring Tool)是用于監(jiān)控虛擬機各種運行狀態(tài)信息的命令行工具。它可以顯示本地或遠程虛擬機(需要遠程主機提供RMI支持)進程中的類裝載、內(nèi)存、垃圾收集、JIT編譯等運行數(shù)據(jù),在沒有GUI圖像界面,只提高了純文本控制臺環(huán)境的服務(wù)器上,它將是運行期定位虛擬機性能問題的首選工具。官方文檔地址為:https://docs.oracle.com/javase/8/docs/technotes/tools/unix/jstat.html
使用jstat -help可以查看使用幫助
C:\Users\Administrator>jstat -help Usage: jstat -help|-options jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]] Definitions: <option> An option reported by the -options option <vmid> Virtual Machine Identifier. A vmid takes the following form: <lvmid>[@<hostname>[:<port>]] Where <lvmid> is the local vm identifier for the target Java virtual machine, typically a process id; <hostname> is the name of the host running the target Java virtual machine; and <port> is the port number for the rmiregistry on the target host. See the jvmstat documentation for a more complete description of the Virtual Machine Identifier. <lines> Number of samples between header lines. <interval> Sampling interval. The following forms are allowed: <n>["ms"|"s"] Where <n> is an integer and the suffix specifies the units as milliseconds("ms") or seconds("s"). The default units are "ms". <count> Number of samples to take before terminating. -J<flag> Pass <flag> directly to the runtime system.
使用jstat -options可以查看jstat支持的option
C:\Users\Administrator>jstat -options -class -compiler -gc -gccapacity -gccause -gcmetacapacity -gcnew -gcnewcapacity -gcold -gcoldcapacity -gcutil -printcompilation
選項option代表這用戶希望查詢的虛擬機信息,主要分為3類:類裝載、垃圾收集和運行期編譯狀況,具體選項及租用參見下表:
選項 | 作用 |
-class | 監(jiān)視類裝載、卸載數(shù)量、總空間及類裝載所耗費的時間 |
-gc | 監(jiān)視Java堆狀況,包括Eden區(qū)、2個Survivor區(qū)、老年代、永久代等的容量 |
-gccapacity | 監(jiān)視內(nèi)容與-gc基本相同,但輸出主要關(guān)注Java堆各個區(qū)域使用到的最大和最小空間 |
-gcutil | 監(jiān)視內(nèi)容與-gc基本相同,但輸出主要關(guān)注已使用空間占總空間的百分比 |
-gccause | 與-gcutil功能一樣,但是會額外輸出導(dǎo)致上一次GC產(chǎn)生的原因 |
-gcnew | 監(jiān)視新生代GC的狀況 |
-gcnewcapacity | 監(jiān)視內(nèi)容與-gcnew基本相同,輸出主要關(guān)注使用到的最大和最小空間 |
-gcold | 監(jiān)視老年代GC的狀況 |
-gcoldcapacity | 監(jiān)視內(nèi)容與——gcold基本相同,輸出主要關(guān)注使用到的最大和最小空間 |
-gcpermcapacity | 輸出永久代使用到的最大和最小空間 |
-compiler | 輸出JIT編譯器編譯過的方法、耗時等信息 |
-printcompilation | 輸出已經(jīng)被JIT編譯的方法 |
其實每個option的輸出內(nèi)容,官方文檔中都有介紹,這里就不把每一個命令都演示一遍了,感興趣的話可以自己試一下,對照著官方文檔還是很好理解的。
jstat命令格式:jstat [option vmid [interval[s|ms] [count]] ]
對于命令格式中的VMID與LVMID需要特別說明下:如果是本地虛擬機進程,VMID和LVMID是一致的,如果是遠程虛擬機進程,那VMID的格式應(yīng)當是:[protocol:][//] lvmid [@hostname[:port]/servername]
參數(shù)interval和count代表查詢間隔和次數(shù),如果省略這兩個參數(shù),說明只查詢一次。假設(shè)需要每1000毫秒查詢一次進程14284垃圾收集狀況,一共查詢5次,那命令行如下:jstat -gc 14284 1000 5
C:\Users\Administrator>jstat -gc 14284 1000 5 S0C S1C S0U S1U EC EU OC OU MC MU CCSC CCSU YGC YGCT FGC FGCT GCT 2176.0 2176.0 0.0 2176.0 17472.0 673.2 43712.0 34800.8 69760.0 66724.9 9088.0 8479.0 620 1.201 57 1.850 3.051 2176.0 2176.0 0.0 2176.0 17472.0 673.2 43712.0 34800.8 69760.0 66724.9 9088.0 8479.0 620 1.201 57 1.850 3.051 2176.0 2176.0 0.0 2176.0 17472.0 673.2 43712.0 34800.8 69760.0 66724.9 9088.0 8479.0 620 1.201 57 1.850 3.051 2176.0 2176.0 0.0 2176.0 17472.0 673.2 43712.0 34800.8 69760.0 66724.9 9088.0 8479.0 620 1.201 57 1.850 3.051 2176.0 2176.0 0.0 2176.0 17472.0 673.2 43712.0 34800.8 69760.0 66724.9 9088.0 8479.0 620 1.201 57 1.850 3.051
通過上面的option表得知-gc用于監(jiān)視Java堆狀況,包括Eden區(qū)、2個Survivor區(qū)、老年代、永久代等的容量,我們對上面的打印做下簡單介紹:
- S0C和S1C表示S0和S1的可用空間都是2176.0KB(注意這里的單位是KB);
- S0U的值表示S0區(qū)域是空的沒有被占用;S1U的值是2176.0KB,說明S1被占滿了;
- EC表示Eden區(qū)域的容量是17472.0KB,EU表示Eden區(qū)使用了673.2KB;
- OC和OU分別表示堆內(nèi)存中的Old區(qū)的容量及使用大小;
- MC和MU分別表示方法區(qū)(JDK1.8元空間)的容量及使用大?。?/li>
- CCSC和CCSU分別表示壓縮類空間的容量及使用大??;
- YGC:年輕代垃圾回收次數(shù)
- YGCT:年輕代垃圾回收消耗時間
- FGC:老年代垃圾回收(FullGC)次數(shù)
- FGCT:老年代垃圾回收(FullGC)消耗時間
- GCT:垃圾回收消耗總時間(等于YGCT+FGCT)
下面再演示下:jstat -gcutil 14284 1000 5
C:\Users\Administrator>jstat -gcutil 14284 1000 5 S0 S1 E O M CCS YGC YGCT FGC FGCT GCT 0.00 100.00 7.31 79.61 95.65 93.30 620 1.201 57 1.850 3.051 0.00 100.00 7.31 79.61 95.65 93.30 620 1.201 57 1.850 3.051 0.00 100.00 7.31 79.61 95.65 93.30 620 1.201 57 1.850 3.051 0.00 100.00 7.31 79.61 95.65 93.30 620 1.201 57 1.850 3.051 0.00 100.00 7.31 79.61 95.65 93.30 620 1.201 57 1.850 3.051
關(guān)于GC時間的上面已經(jīng)介紹了,可以結(jié)合上面的jstat -gc看一下:
- S0:S0區(qū)當前使用比例為0.00%,也就是空的
- S1:S1區(qū)當前使用比例100.00%,已經(jīng)滿了
- E:Eden區(qū)使用比例7.31%
- O:老年代使用比例79.61%
- M:元空間使用比例95.65%
- CCS:壓縮類空間使用比例93.30%
本節(jié)就先介紹到這里,下節(jié)會介紹jmap+MAT實戰(zhàn)堆內(nèi)存溢出分析。
到此這篇關(guān)于JDK常用命令jps jinfo jstat的具體說明與示例的文章就介紹到這了,更多相關(guān)JDK 常用命令 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java多線程之線程,進程和Synchronized概念初解
這篇文章主要介紹了java多線程之線程,進程和Synchronized概念初解,涉及進程與線程的簡單概念,實現(xiàn)多線程的方式,線程安全問題,synchronized修飾符等相關(guān)內(nèi)容,具有一定借鑒價值,需要的朋友可以參考下。2017-11-11SpringBoot + Shiro前后端分離權(quán)限
這篇文章主要為大家詳細介紹了SpringBoot + Shiro前后端分離權(quán)限,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-12-12在Ubuntu上部署SpringBoot應(yīng)用的操作步驟
隨著云計算和容器化技術(shù)的普及,Linux 服務(wù)器已成為部署 Web 應(yīng)用程序的主流平臺之一,Java 作為一種跨平臺的編程語言,具有廣泛的應(yīng)用場景,本文將詳細介紹如何在 Ubuntu 服務(wù)器上部署 Java 應(yīng)用,需要的朋友可以參考下2025-01-01SpringBoot AOP AspectJ切面技術(shù)介紹與實現(xiàn)方式
這篇文章主要介紹了Springboot如何使用Aspectj實現(xiàn)AOP面向切面編程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10