欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JDK常用命令jps jinfo jstat的具體說明與示例

 更新時間:2021年09月24日 17:28:24   作者:沒頭腦遇到不高興  
JDK本身提供了很多方便的JVM性能調(diào)優(yōu)監(jiān)控工具,除了集成式的VisualVM和jConsole外,還有jps、jinfo、jstat等小巧的工具,本文章希望能起拋磚引玉之用,讓大家能開始對JVM性能調(diào)優(yōu)的常用工具有所了解

概述

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字符串split方法的坑及解決

    Java字符串split方法的坑及解決

    這篇文章主要介紹了Java字符串split方法的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • java多線程之線程,進程和Synchronized概念初解

    java多線程之線程,進程和Synchronized概念初解

    這篇文章主要介紹了java多線程之線程,進程和Synchronized概念初解,涉及進程與線程的簡單概念,實現(xiàn)多線程的方式,線程安全問題,synchronized修飾符等相關(guān)內(nèi)容,具有一定借鑒價值,需要的朋友可以參考下。
    2017-11-11
  • java 從服務(wù)器下載文件并保存到本地的示例

    java 從服務(wù)器下載文件并保存到本地的示例

    本篇文章主要介紹了java 從服務(wù)器下載文件并保存到本地的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02
  • java中final與finally的使用介紹

    java中final與finally的使用介紹

    本篇文章介紹了,在java中final與finally的使用。需要的朋友參考下
    2013-04-04
  • Bean的管理與SpringBoot自動裝配原理解讀

    Bean的管理與SpringBoot自動裝配原理解讀

    在SpringBoot項目中,啟動時自動創(chuàng)建IOC容器并初始化bean對象,支持通過依賴注入獲取,Bean可以通過name或類型獲取,支持單例和非單例等多種作用域,對于第三方Bean,推薦在配置類中用@Bean標識方法進行定義
    2024-11-11
  • SpringBoot + Shiro前后端分離權(quán)限

    SpringBoot + Shiro前后端分離權(quán)限

    這篇文章主要為大家詳細介紹了SpringBoot + Shiro前后端分離權(quán)限,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • IntelliJ IDEA使用SVN分支的簡單介紹

    IntelliJ IDEA使用SVN分支的簡單介紹

    今天小編就為大家分享一篇關(guān)于IntelliJ IDEA使用SVN分支的簡單介紹,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-10-10
  • 在Ubuntu上部署SpringBoot應(yīng)用的操作步驟

    在Ubuntu上部署SpringBoot應(yīng)用的操作步驟

    隨著云計算和容器化技術(shù)的普及,Linux 服務(wù)器已成為部署 Web 應(yīng)用程序的主流平臺之一,Java 作為一種跨平臺的編程語言,具有廣泛的應(yīng)用場景,本文將詳細介紹如何在 Ubuntu 服務(wù)器上部署 Java 應(yīng)用,需要的朋友可以參考下
    2025-01-01
  • 淺析java 歸并排序算法

    淺析java 歸并排序算法

    這篇文章主要簡單介紹了java 歸并排序算法的工作原理及代碼,需要的朋友可以參考下
    2015-02-02
  • SpringBoot AOP AspectJ切面技術(shù)介紹與實現(xiàn)方式

    SpringBoot AOP AspectJ切面技術(shù)介紹與實現(xiàn)方式

    這篇文章主要介紹了Springboot如何使用Aspectj實現(xiàn)AOP面向切面編程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10

最新評論