JDK自带VM分析工具jps,jstat,jmap,jconsole
一、概述?
??? SUN 的JDK中的幾個工具,非常好用。秉承著有免費,不用商用的原則。以下簡單介紹一下這幾種工具。(注:本文章下的所有工具都存在JDK5.0以上版本的工具集里,同javac一樣,不須特意安裝)? 。
??? ??
??? 我一共找到以下四個工具:重點看看jconsole和jmap。
?
二、 使用介紹:??
??? ??
??? 1、jps:我想很多人都是用過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 -gcutil pid:統計gc信息統計。??
??? jstat -printcompilation pid:當前VM執行的信息。??
??? 除了以上一個參數外,還可以同時加上 兩個數字,如:jstat -printcompilation 3024 250 6是每250毫秒打印一次,一共打印6次,還可以加上-h3每三行顯示一下標題。?
??? ??
查看GC時,各列對應關系:?S0C??? S1C??? S0U??? S1U????? EC?????? EU??????? OC???????? OU?????? PC???? PU??? YGC???? YGCT??? FGC??? FGCT???? GCT
| S0C | Current survivor space 0 capacity (KB). |
| EC | Current eden space capacity (KB). |
| EU | Eden space utilization (KB). |
| OC | Current old space capacity (KB). |
| OU | Old space utilization (KB). |
| PC | Current permanent space capacity (KB). |
| PU | Permanent space utilization (KB). |
| YGC | Number of young generation GC Events. |
| YGCT | Young generation garbage collection time. |
| FGC | Number of full GC events. |
| FGCT | Full garbage collection time. |
| GCT | Total garbage collection time. |
???
jstat -gcutil PID interval? count
S0? — Heap上的 Survivor space 0 區已使用空間的百分比
S1? — Heap上的 Survivor space 1 區已使用空間的百分比
E?? — Heap上的 Eden space 區已使用空間的百分比
O?? — Heap上的 Old space 區已使用空間的百分比
P?? — Perm space 區已使用空間的百分比
YGC — 從應用程序啟動到采樣時發生 Young GC 的次數
YGCT– 從應用程序啟動到采樣時 Young GC 所用的時間(單位秒)
FGC — 從應用程序啟動到采樣時發生 Full GC 的次數
FGCT– 從應用程序啟動到采樣時 Full GC 所用的時間(單位秒)
GCT — 從應用程序啟動到采樣時用于垃圾回收的總時間(單位秒)
jstat 用法http://eecn.blog.sohu.com/177061930.html
??? 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 ? ? ??
總結
以上是生活随笔為你收集整理的JDK自带VM分析工具jps,jstat,jmap,jconsole的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: NoSQL学习笔记(二)之CAP理论
- 下一篇: java事务类型