[轉載]JDK自帶VM分析工具jps,jstat,jmap,jconsole
一、概述
SUN 的JDK中的幾個工具,非常好用。秉承著有免費,不用商用的原則。以下簡單介紹一下這幾種工具。(注:本文章下的所有工具都存在JDK5.0以上版本的工具集裡,同javac一樣,不須特意安裝) 。
我一共找到以下四個工具:重點看看jconsole和jmap。
二、 使用介紹:
1、jstat :我想很多人都是用過unix系統裡的ps命令,這個命令主要是用來顯示當前系統的程式情況,有哪些程式,及其 id。 jps 也是一樣,它的作用是顯示當前系統的java程式情況,及其id號。我們可以通過它來檢視我們到底啟動了幾個java程式(因為每一個java程式都會獨佔一個java虛擬機器例項),和他們的程式號(為下面幾個程式做準備),並可通過opt來檢視這些程式的詳細啟動引數。
使用方法:在當前命令列下打 jps(需要JAVA_HOME,沒有的話,到改程式的目錄下打) 。
可惜沒有linux下的ps好用,名稱不好用。但是在第四個工具jconsole的介面裡面會有具體JAR包的名稱。
2、jstat :對VM記憶體使用量進行監控。
jstat工具特別強大,有眾多的可選項,詳細檢視堆內各個部分的使用量,以及載入類的數量。使用時,需加上檢視程式的程式id,和所選引數。以下詳細介紹各個引數的意義。
jstat -class pid:顯示載入class的數量,及所佔空間等資訊。
jstat -compiler pid:顯示VM實時編譯的數量等資訊。
jstat -gc pid:可以顯示gc的資訊,檢視gc的次數,及時間。其中最後五項,分別是young gc的次數,young gc的時間,full gc的次數,full gc的時間,gc的總時間。
jstat -gccapacity:可以顯示,VM記憶體中三代(young,old,perm)物件的使用和佔用大小,如:PGCMN顯示的是最小perm的記憶體使用量,PGCMX顯示的是perm的記憶體最大使用量,PGC是當前新生成的perm記憶體佔用量,PC是但前perm記憶體佔用量。其他的可以根據這個類推, OC是old內純的佔用量。
jstat -gcnew pid:new物件的資訊。
jstat -gcnewcapacity pid:new物件的資訊及其佔用量。
jstat -gcold pid:old物件的資訊。
jstat -gcoldcapacity pid:old物件的資訊及其佔用量。
jstat -gcpermcapacity pid: perm物件的資訊及其佔用量。
jstat -util pid:統計gc資訊統計。
jstat -printcompilation pid:當前VM執行的資訊。
除了以上一個引數外,還可以同時加上 兩個數字,如:jstat -printcompilation 3024 250 6是每250毫秒列印一次,一共列印6次,還可以加上-h3每三行顯示一下標題。
3、jmap 是一個可以輸出所有記憶體中物件的工具,甚至可以將VM 中的heap,以二進位制輸出成文字。使用方法 jmap -histo pid。如果連用 SHELL jmap -histo pid>a.log可以將其儲存到文字中去(windows下也可以使用),在一段時間後,使用文字對比工具,可以對比出GC回收了哪些物件。jmap -dump:format=b,file=f1 3024可以將3024程式的記憶體heap輸出出來到f1檔案裡。
4、jconsole 是一個用java寫的GUI程式,用來監控VM,並可監控遠端的VM,非常易用,而且功能非常強。由於是GUI程式,這裡就不詳細介紹了,不會的地方可以參考SUN的官方文件。
使用方法:命令列裡打 jconsole,選則程式就可以了。
友好提示:windows檢視程式號,由於工作管理員預設的情況下是不顯示程式id號的,所以可以通過如下方法加上。ctrl+alt+del開啟工作管理員,選擇‘程式’選項卡,點‘檢視’->''選擇列''->加上''PID'',就可以了。當然還有其他很好的選項。
三、參考資料:
article:http://elf8848.iteye.com/blog/442806
jps:http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/jps.html
jstat:http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/jstat.html
jmap:http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/jmap.html
jconsole:http://java.sun.com/j2se/1.5.0/docs/guide/management/jconsole.html
轉載地址:http://jiajun.iteye.com/blog/443196,本博主對其中內容正確與否不負責任,請尊重原作者版權。
SUN 的JDK中的幾個工具,非常好用。秉承著有免費,不用商用的原則。以下簡單介紹一下這幾種工具。(注:本文章下的所有工具都存在JDK5.0以上版本的工具集裡,同javac一樣,不須特意安裝) 。
我一共找到以下四個工具:重點看看jconsole和jmap。
jps
:與unix上的ps類似,用來顯示本地的java程式,可以檢視本地執行著幾個java程式,並顯示他們的程式號。
jstat
:一個極強的監視VM記憶體工具。可以用來監視VM記憶體內的各種堆和非堆的大小及其記憶體使用量。
jmap
:列印出某個java程式(使用pid)記憶體內的,所有‘物件’的情況(如:產生那些物件,及其數量)。
jconsole
:一個java GUI監視工具,可以以圖表化的形式顯示各種資料。並可通過遠端連線監視遠端的伺服器VM。
二、 使用介紹:
1、jstat :我想很多人都是用過unix系統裡的ps命令,這個命令主要是用來顯示當前系統的程式情況,有哪些程式,及其 id。 jps 也是一樣,它的作用是顯示當前系統的java程式情況,及其id號。我們可以通過它來檢視我們到底啟動了幾個java程式(因為每一個java程式都會獨佔一個java虛擬機器例項),和他們的程式號(為下面幾個程式做準備),並可通過opt來檢視這些程式的詳細啟動引數。
使用方法:在當前命令列下打 jps(需要JAVA_HOME,沒有的話,到改程式的目錄下打) 。
可惜沒有linux下的ps好用,名稱不好用。但是在第四個工具jconsole的介面裡面會有具體JAR包的名稱。
2、jstat :對VM記憶體使用量進行監控。
jstat工具特別強大,有眾多的可選項,詳細檢視堆內各個部分的使用量,以及載入類的數量。使用時,需加上檢視程式的程式id,和所選引數。以下詳細介紹各個引數的意義。
jstat -class pid:顯示載入class的數量,及所佔空間等資訊。
jstat -compiler pid:顯示VM實時編譯的數量等資訊。
jstat -gc pid:可以顯示gc的資訊,檢視gc的次數,及時間。其中最後五項,分別是young gc的次數,young gc的時間,full gc的次數,full gc的時間,gc的總時間。
jstat -gccapacity:可以顯示,VM記憶體中三代(young,old,perm)物件的使用和佔用大小,如:PGCMN顯示的是最小perm的記憶體使用量,PGCMX顯示的是perm的記憶體最大使用量,PGC是當前新生成的perm記憶體佔用量,PC是但前perm記憶體佔用量。其他的可以根據這個類推, OC是old內純的佔用量。
jstat -gcnew pid:new物件的資訊。
jstat -gcnewcapacity pid:new物件的資訊及其佔用量。
jstat -gcold pid:old物件的資訊。
jstat -gcoldcapacity pid:old物件的資訊及其佔用量。
jstat -gcpermcapacity pid: perm物件的資訊及其佔用量。
jstat -util pid:統計gc資訊統計。
jstat -printcompilation pid:當前VM執行的資訊。
除了以上一個引數外,還可以同時加上 兩個數字,如:jstat -printcompilation 3024 250 6是每250毫秒列印一次,一共列印6次,還可以加上-h3每三行顯示一下標題。
3、jmap 是一個可以輸出所有記憶體中物件的工具,甚至可以將VM 中的heap,以二進位制輸出成文字。使用方法 jmap -histo pid。如果連用 SHELL jmap -histo pid>a.log可以將其儲存到文字中去(windows下也可以使用),在一段時間後,使用文字對比工具,可以對比出GC回收了哪些物件。jmap -dump:format=b,file=f1 3024可以將3024程式的記憶體heap輸出出來到f1檔案裡。
4、jconsole 是一個用java寫的GUI程式,用來監控VM,並可監控遠端的VM,非常易用,而且功能非常強。由於是GUI程式,這裡就不詳細介紹了,不會的地方可以參考SUN的官方文件。
使用方法:命令列裡打 jconsole,選則程式就可以了。
友好提示:windows檢視程式號,由於工作管理員預設的情況下是不顯示程式id號的,所以可以通過如下方法加上。ctrl+alt+del開啟工作管理員,選擇‘程式’選項卡,點‘檢視’->''選擇列''->加上''PID'',就可以了。當然還有其他很好的選項。
三、參考資料:
article:http://elf8848.iteye.com/blog/442806
jps:http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/jps.html
jstat:http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/jstat.html
jmap:http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/jmap.html
jconsole:http://java.sun.com/j2se/1.5.0/docs/guide/management/jconsole.html
轉載地址:http://jiajun.iteye.com/blog/443196,本博主對其中內容正確與否不負責任,請尊重原作者版權。
相關文章
- JDK幾個很實用的工具 jps、jinfo、jstat、jstack、jmap、jconsoleJDKJS
- JVM監控工具:jps、jstat、jinfo、jmap、jhat、jJVMJS
- Java命令列監控工具(jmap,jstack,jstat,jinfo,jps)Java命令列JS
- Java——命令jps、jstat、jmap、jstack、jhat、jinfoJavaJS
- JVM效能調優監控工具——jps、jstack、jmap、jhat、jstat、hprof使用詳解JVMJS
- java虛擬機器記憶體監控工具jps,jinfo,Jstack,jstat,jmap,jhat使用Java虛擬機記憶體JS
- jvm系列(四):jvm調優-命令大全(jps jstat jmap jhat jstack jinfo)JVMJS
- JDK中自帶的JVM分析工具JDKJVM
- Java命令列監控工具(jmap,jstack,jstat,jinfoJava命令列JS
- (轉)JVM調優常用命令(jstat、jmap、jstack)JVMJS
- 使用JDK工具jmap和jhat監控Java程式JDKJava
- 使用JDK自帶的jmap和jhat監控處於執行狀態的Java程式JDKJava
- 一些JDK自帶的效能分析利器JDK
- JDK14效能管理工具:jstat使用介紹JDKJS
- Java JDK目錄下的jmap和jhat工具的使用方式JavaJDK
- 面試官:你用過哪些JDK自帶的命令列工具面試JDK命令列
- jstack, jstat, jmap, jinfo, 教你如何在背後偷窺你的程式^^JS
- 案例面試分析工具/框架(轉載)面試框架
- 使用JDK自帶的VisualVM進行Java程式的效能分析JDKLVMJava
- JDK的幾種分析工具JDK
- jvm(四)——JVM自帶記憶體分析工具詳解JVM記憶體
- 使用JDK自帶的工具jstack找出造成執行程式死鎖的原因JDKJS行程
- 使用CentOS 7.5解除安裝自帶jdk安裝自己的JDK1.8CentOSJDK
- 【閱讀筆記】jvm效能工具-jstat解決100%CPU佔用率分析筆記JVMJS
- IDEA使用自帶下載的open jdk導致控制檯輸出中文亂碼IdeaJDK
- Chrome 自帶開發者工具筆記Chrome筆記
- VS自帶工具:dumpbin的使用
- Jvm自帶監控命令實戰[base jdk8]JVMJDK
- Jconsole與Jmx 分析JVM狀況(上)JVM
- JPS/JPS+ 尋路演算法演算法
- win10自帶畫圖工具在哪裡 電腦自帶的畫圖工具使用教程Win10
- win2000遠端桌面自帶工具下載使用方法
- oracle 自帶錯誤提示工具oerrOracle
- hbase自帶的測試工具PerformanceEvaluationORM
- 請問,如何讓jdk1.5的jconsole監聽到mbean server?JDKBeanServer
- win10如何使用自帶遷移工具 win10使用自帶遷移工具的方法Win10
- jstat命令JS
- oracle VM掛載光碟機Oracle