jstat,jmap,jconsole,jvisualvm,jps,jinfo等JDK系統(tǒng)監(jiān)控、性能調(diào)優(yōu)工具
@import url(http://www.aygfsteel.com/CuteSoft_Client/CuteEditor/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/css/cuteeditor.css); @import url(http://www.aygfsteel.com/CuteSoft_Client/CuteEditor/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/css/cuteeditor.css);工具名稱:IBM HeapAnalyzer
JProfiler在java程序性能調(diào)試方便表現(xiàn)優(yōu)越,推薦使用。也可使用下面jdk自己的一些工具。
所有工具都在JDK/bin目錄下, jconsole和jvisualvm為GUI圖形化工具,其他為命令行。
jvisualvm: GUI工具,可監(jiān)控、性能評(píng)估、故障診斷主機(jī)上所有java進(jìn)程的cpu,內(nèi)存,線程使用情況,類似于JProfiler,嚴(yán)重推薦。
jinfo:可以輸出并修改運(yùn)行時(shí)的java 進(jìn)程的opts。
jps:與unix上的ps類似,用來(lái)顯示本地的java進(jìn)程,可以查看本地運(yùn)行著幾個(gè)java程序,并顯示他們的進(jìn)程號(hào)。
jstat:一個(gè)極強(qiáng)的監(jiān)視VM內(nèi)存工具。可以用來(lái)監(jiān)視VM內(nèi)存內(nèi)的各種堆和非堆的大小及其內(nèi)存使用量。
jmap:打印出某個(gè)java進(jìn)程(使用pid)內(nèi)存內(nèi)的,所有‘對(duì)象’的情況(如:產(chǎn)生那些對(duì)象,及其數(shù)量)。
jconsole:一個(gè)java GUI監(jiān)視工具,可以以圖表化的形式顯示各種數(shù)據(jù)。并可通過遠(yuǎn)程連接監(jiān)視遠(yuǎn)程的服務(wù)器VM。
jstat工具特別強(qiáng)大,有眾多的可選項(xiàng),詳細(xì)查看堆內(nèi)各個(gè)部分的使用量,以及加載類的數(shù)量。使用時(shí),需加上查看進(jìn)程的進(jìn)程id,和所選參數(shù)。以下詳細(xì)介紹各個(gè)參數(shù)的意義。
jstat -class pid:顯示加載class的數(shù)量,及所占空間等信息。
jstat -compiler pid:顯示VM實(shí)時(shí)編譯的數(shù)量等信息。
jstat -gc pid:可以顯示gc的信息,查看gc的次數(shù),及時(shí)間。其中最后五項(xiàng),分別是young gc的次數(shù),young gc的時(shí)間,full gc的次數(shù),full gc的時(shí)間,gc的總時(shí)間。
jstat -gccapacity:可以顯示,VM內(nèi)存中三代(young,old,perm)對(duì)象的使用和占用大小,如:PGCMN顯示的是最小perm的內(nèi)存使用量,PGCMX顯示的是perm的內(nèi)存最大使用量,PGC是當(dāng)前新生成的perm內(nèi)存占用量,PC是但前perm內(nèi)存占用量。其他的可以根據(jù)這個(gè)類推, OC是old內(nèi)純的占用量。
jstat -gcnew pid:new對(duì)象的信息。
jstat -gcnewcapacity pid:new對(duì)象的信息及其占用量。
jstat -gcold pid:old對(duì)象的信息。
jstat -gcoldcapacity pid:old對(duì)象的信息及其占用量。
jstat -gcpermcapacity pid: perm對(duì)象的信息及其占用量。
jstat -util pid:統(tǒng)計(jì)gc信息統(tǒng)計(jì)。
jstat -printcompilation pid:當(dāng)前VM執(zhí)行的信息。
除了以上一個(gè)參數(shù)外,還可以同時(shí)加上 兩個(gè)數(shù)字,如:jstat -printcompilation 3024 250 6是每250毫秒打印一次,一共打印6次,還可以加上-h3每三行顯示一下標(biāo)題。
jmap是一個(gè)可以輸出所有內(nèi)存中對(duì)象的工具,甚至可以將VM 中的heap,以二進(jìn)制輸出成文本。使用方法 jmap -histo pid。如果連用SHELL jmap -histo pid>a.log可以將其保存到文本中去,在一段時(shí)間后,使用文本對(duì)比工具,可以對(duì)比出GC回收了哪些對(duì)象。jmap -dump:format=b,file=String 3024可以將3024進(jìn)程的內(nèi)存heap輸出出來(lái)到String文件里。
jinfo:的用處比較簡(jiǎn)單,就是能輸出并修改運(yùn)行時(shí)的java進(jìn)程的運(yùn)行參數(shù)。用法是jinfo -opt pid 如:查看2788的MaxPerm大小可以用 jinfo -flag MaxPermSize 2788。
jconsole是一個(gè)用java寫的GUI程序,用來(lái)監(jiān)控VM,并可監(jiān)控遠(yuǎn)程的VM,非常易用,而且功能非常強(qiáng)。由于是GUI程序,這里就不詳細(xì)介紹了,不會(huì)的地方可以參考SUN的官方文檔。
使用方法:命令行里打 jconsole,選則進(jìn)程就可以了。
SUN官方說(shuō)明:
jvisualvm: http://java.sun.com/javase/6/docs/technotes/tools/share/jvisualvm.html
jps:http://java.sun.com/javase/6/docs/technotes/tools/share/jps.html
jstat:http://java.sun.com/javase/6/docs/technotes/tools/share/jstat.html
jmap:http://java.sun.com/javase/6/docs/technotes/tools/share/jmap.html
jconsole:http://java.sun.com/javase/6/docs/technotes/tools/share/jconsole.html
在一次解決系統(tǒng)tomcat老是內(nèi)存撐到頭,然后崩潰的問題時(shí),使用到了jmap。
1 使用命令
在環(huán)境是linux+jdk1.5以上,這個(gè)工具是自帶的,路徑在JDK_HOME/bin/下
jmap -histo pid>a.log
2 輸出結(jié)果摘要
Size Count Class description
-------------------------------------------------------
353371288 9652324 char[]
230711112 9612963 java.lang.String
139347160 114865 byte[]
76128096 3172004 java.util.Hashtable$Entry
75782280 3157595 com.test.util.IPSeeker$IPLocation
25724272 9115 java.util.Hashtable$Entry[]
9319968 166428 org.apache.tomcat.util.buf.MessageBytes
8533856 32889 int[]
發(fā)現(xiàn)有大量的String和自定義對(duì)象com.test.util.IPSeeker$IPLocation存在,檢查程序發(fā)現(xiàn)此處果然存在內(nèi)存溢出。修改程序上線后再次用jmap抓取內(nèi)存數(shù)據(jù):
146881712 207163 byte[]
98976352 354285 char[]
42595272 53558 int[]
11515632 479818 java.util.HashMap$Entry
9521896 59808 java.util.HashMap$Entry[]
8887392 370308 com.test.bean.UnionIPEntry
8704808 155443 org.apache.tomcat.util.buf.MessageBytes
8066880 336120 java.lang.String
內(nèi)存溢出問題消除。
注意:這個(gè)jmap使用的時(shí)候jvm是處在假死狀態(tài)的,只能在服務(wù)癱瘓的時(shí)候?yàn)榱私鉀Q問題來(lái)使用,否則會(huì)造成服務(wù)中斷。
posted on 2012-02-07 17:02 tobyxiong 閱讀(2254) 評(píng)論(0) 編輯 收藏 所屬分類: java