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

深入淺析jcmd:JDK14中的調(diào)試神器

 更新時間:2020年04月29日 09:34:47   作者:flydean  
這篇文章主要介紹了jcmd:JDK14中的調(diào)試神器,本文給大家提到了jcmd的語法,通過實例列舉的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

jcmd是JDK自帶的調(diào)試工具,具有非常強大的功能。jcmd是JDK7中正式引入的,有了jcmd,完全可以替換很多常用的其他工具,比如jstak和jmap。

jcmd可以將具體的診斷命令發(fā)送給JVM。為了安全起見,使用jcmd的用戶必須跟運行的java程序具有同樣的用戶和用戶組。

jcmd的調(diào)試命令有很多種,每一種調(diào)試命令又有自己的參數(shù)。

本文將會結(jié)合具體的例子詳細(xì)講解jcmd的使用。

jcmd的語法

jcmd的語法比較簡單:

jcmd [pid | main-class] command... | PerfCounter.print | -f filename

jcmd [-l]

jcmd -h

pid和main-class是二選一:

其中pid表示要發(fā)送診斷命令的java進(jìn)程id。

也可以指定main-class,表示要發(fā)送診斷命令給運行該main-class的java進(jìn)程。

command表示可以在jcmd中運行的命令,我們看下jcmd支持哪些命令:

./jcmd 93989 help
93989:
The following commands are available:
Compiler.CodeHeap_Analytics
Compiler.codecache
Compiler.codelist
Compiler.directives_add
Compiler.directives_clear
Compiler.directives_print
Compiler.directives_remove
Compiler.queue
GC.class_histogram
GC.class_stats
GC.finalizer_info
GC.heap_dump
GC.heap_info
GC.run
GC.run_finalization
JFR.check
JFR.configure
JFR.dump
JFR.start
JFR.stop
JVMTI.agent_load
JVMTI.data_dump
ManagementAgent.start
ManagementAgent.start_local
ManagementAgent.status
ManagementAgent.stop
Thread.print
VM.class_hierarchy
VM.classloader_stats
VM.classloaders
VM.command_line
VM.dynlibs
VM.events
VM.flags
VM.info
VM.log
VM.metaspace
VM.native_memory
VM.print_touched_methods
VM.set_flag
VM.stringtable
VM.symboltable
VM.system_properties
VM.systemdictionary
VM.uptime
VM.version
help

Perfcounter.print表示要打印java進(jìn)程暴露的performance counters。

-f filename表示從文本文件中讀取要運行的命令。

-l 列出不是運行在docker中JVM。

-h 表示幫助。

下面我們舉幾個常用的例子

列出運行的JVM

./jcmd -l
98109 jdk.jcmd/sun.tools.jcmd.JCmd -l

通過使用jcmd -l可以列出所有正在運行的JVM進(jìn)程。跟jps是一樣的。

打印stack信息

使用jcmd pid Thread.print -l可以打印出java程序的stack信息。其中-l表示輸出java.util.concurrent的lock信息。

下面看個簡單的例子:

./jcmd 93989 Thread.print -l

Full thread dump Java HotSpot(TM) 64-Bit Server VM (14.0.1+7 mixed mode, sharing):

Threads class SMR info:
_java_thread_list=0x00007fbeb1c4cb10, length=12, elements={
0x00007fbeb282a800, 0x00007fbeb282d800, 0x00007fbeb282e800, 0x00007fbeb2830800,
0x00007fbeb2831800, 0x00007fbeb2832000, 0x00007fbeb2833000, 0x00007fbeb3831000,
0x00007fbeb3822000, 0x00007fbeb3174000, 0x00007fbeb3815000, 0x00007fbeb226f800
}

"Reference Handler" #2 daemon prio=10 os_prio=31 cpu=0.64ms elapsed=8996.59s tid=0x00007fbeb282a800 nid=0x4703 waiting on condition [0x000070000440d000]
 java.lang.Thread.State: RUNNABLE
 at java.lang.ref.Reference.waitForReferencePendingList(java.base@14.0.1/Native Method)
 at java.lang.ref.Reference.processPendingReferences(java.base@14.0.1/Reference.java:241)
 at java.lang.ref.Reference$ReferenceHandler.run(java.base@14.0.1/Reference.java:213)

 Locked ownable synchronizers:
 - None

打印heap info

使用jcmd pid GC.heap_info可以獲得heap info。

./jcmd 93989 GC.heap_info
93989:
 garbage-first heap total 71680K, used 34410K [0x00000007d4400000, 0x0000000800000000)
 region size 1024K, 20 young (20480K), 4 survivors (4096K)
 Metaspace used 23810K, capacity 24246K, committed 24752K, reserved 1071104K
 class space used 2850K, capacity 3015K, committed 3072K, reserved 1048576K

打印heap dump

如果想知道heap里面到底有什么,則可以通過下面的命令將heap dump出來:

./jcmd 93989 GC.heap_dump heap_dump.out
93989:
Dumping heap to heap_dump.out ...
Heap dump file created [27727979 bytes in 0.643 secs]

heap dump需要傳入一個文件名,存放dump出來的信息。

統(tǒng)計heap使用情況

有時候我們需要統(tǒng)計一下heap中各個對象的使用情況,則可以下面方法:

./jcmd 93989 GC.class_histogram

93989:
 num #instances #bytes class name (module)
-------------------------------------------------------
 1: 25826 11748304 [B (java.base@14.0.1)
 2: 2233 1971800 [I (java.base@14.0.1)
 3: 5154 614928 java.lang.Class (java.base@14.0.1)
 4: 24757 594168 java.lang.String (java.base@14.0.1)
 5: 4491 439432 [Ljava.lang.Object; (java.base@14.0.1)
 6: 13177 421664 java.util.concurrent.ConcurrentHashMap$Node (java.base@14.0.1)
 7: 5025 160800 java.util.HashMap$Node (java.base@14.0.1)
 8: 8793 140688 java.lang.Object (java.base@14.0.1)
 9: 212 103584 [Ljava.util.concurrent.ConcurrentHashMap$Node; (java.base@14.0.1)

上面的結(jié)果非常有用,在一些性能調(diào)試方法可以起到意想不到的作用。

JFR功能

jcmd還支持jfr功能。JFR的全稱叫做Java Flight Recorder。你可以將其看做是JVM中一些事件的記錄器。

有關(guān)JFR的更多內(nèi)容,可以點擊查閱:http://www.dbjr.com.cn/article/185648.htm

http://www.dbjr.com.cn/article/185707.htm

到此這篇關(guān)于深入淺析jcmd:JDK14中的調(diào)試神器的文章就介紹到這了,更多相關(guān)jcmd:JDK14調(diào)試神器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java后臺調(diào)用接口及處理跨域問題的解決

    java后臺調(diào)用接口及處理跨域問題的解決

    這篇文章主要介紹了java后臺調(diào)用接口,處理跨域的問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • springboot啟動時如何指定spring.profiles.active

    springboot啟動時如何指定spring.profiles.active

    這篇文章主要介紹了springboot啟動時如何指定spring.profiles.active問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Java 在PDF中添加騎縫章示例解析

    Java 在PDF中添加騎縫章示例解析

    這篇文章主要介紹了Java 在PDF中添加騎縫章示例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • IDEA2020.1創(chuàng)建springboot項目(國內(nèi)腳手架)安裝lombok

    IDEA2020.1創(chuàng)建springboot項目(國內(nèi)腳手架)安裝lombok

    這篇文章主要介紹了IDEA2020.1創(chuàng)建springboot項目(國內(nèi)腳手架)安裝lombok,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • IntelliJ IDEA之高效代碼插件RainBow Brackets詳解

    IntelliJ IDEA之高效代碼插件RainBow Brackets詳解

    這篇文章主要介紹了IntelliJ IDEA之高效代碼插件RainBow Brackets詳解,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12
  • Springboot2集成pagehelper過程圖解

    Springboot2集成pagehelper過程圖解

    這篇文章主要介紹了springboot2集成pagehelper過程圖解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-03-03
  • Java實現(xiàn)占位符名稱替換值

    Java實現(xiàn)占位符名稱替換值

    占位符現(xiàn)在應(yīng)該說是比較流行的動態(tài)賦值,本文主要介紹了Java占位符名稱替換值,根據(jù)一串帶著參數(shù)名占位符的url,替換掉對應(yīng)參數(shù)名的值,感興趣的可以了解一下
    2021-07-07
  • 淺談springboot多模塊(modules)開發(fā)

    淺談springboot多模塊(modules)開發(fā)

    這篇文章主要介紹了淺談springboot多模塊(modules)開發(fā),詳細(xì)的介紹了springboot多模塊的實現(xiàn),有興趣的可以了解一下
    2017-09-09
  • Java線程三種命名方法詳解

    Java線程三種命名方法詳解

    這篇文章主要介紹了Java線程三種命名方法詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-02-02
  • java實現(xiàn)多線程賣票功能

    java實現(xiàn)多線程賣票功能

    這篇文章主要為大家詳細(xì)介紹了java實現(xiàn)多線程賣票功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-07-07

最新評論