命令行工具:jps、jstack、jmap、jhat、jstat、hprof

JVM性能調(diào)優(yōu)監(jiān)控工具jps、jstack、jmap、jhat、jstat、hprof使用詳解

  1. jps(Java Virtual Machine Process Status Tool)
    jsp詳細說明

  2. jstack
    jstack詳細說明

  3. jmap(Memory Map)和jhat(Java Heap Analysis Tool)
    jmap詳細說明

  4. jstat(JVM統(tǒng)計監(jiān)測工具)
    jstat詳細說明

  5. hprof(Heap/CPU Profiling Tool)

hprof能夠展現(xiàn)CPU使用率,統(tǒng)計堆內(nèi)存使用情況。

來幾個官方指南上的實例。
CPU Usage Sampling Profiling(cpu=samples)的例子:

java -agentlib:hprof=cpu=sample,interval=20,depth=3 Hello

上面每隔20毫秒采樣CPU消耗信息,堆棧深度為3,生成的profile文件名稱是java.hprof.txt,在當前目錄。
CPU Usage Times Profiling(cpu=times)的例子,它相對于CPU Usage Sampling Profile能夠獲得更加細粒度的CPU消耗信息,能夠細到每個方法調(diào)用的開始和結(jié)束,它的實現(xiàn)使用了字節(jié)碼注入技術(BCI):

javac -J-agentlib:hprof=cpu=times Hello.java

Heap Allocation Profiling(heap=sites)的例子:

javac -J-agentlib:hprof=heap=sites Hello.java

Heap Dump(heap=dump)的例子,它比上面的Heap Allocation Profiling能生成更詳細的Heap Dump信息:

javac -J-agentlib:hprof=heap=dump Hello.java

雖然在JVM啟動參數(shù)中加入-Xrunprof:heap=sites參數(shù)可以生成CPU/Heap Profile文件,但對JVM性能影響非常大,不建議在線上服務器環(huán)境使用。

參考

?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容