使用Jstat監(jiān)控gc情況(收藏)
?
性能測(cè)試過(guò)程中,我們?cè)撊绾伪O(jiān)控java虛擬機(jī)內(nèi)存的使用情況,用以判斷JVM是否存在內(nèi)存問(wèn)題呢?如何判斷JVM垃圾回收是否正常?一般的top指令基本上滿足不了這樣的需求,因?yàn)樗饕O(jiān)控的是總體的系統(tǒng)資源,很難定位到j(luò)ava應(yīng)用程序。
在項(xiàng)目實(shí)踐過(guò)程中,我們探索和使用了一款新工具--Jstat。
??? 先秀一下。Jstat是JDK自帶的一個(gè)輕量級(jí)小工具。全稱“Java Virtual Machine statistics monitoring tool”,它位于java的bin目錄下,主要利用JVM內(nèi)建的指令對(duì)Java應(yīng)用程序的資源和性能進(jìn)行實(shí)時(shí)的命令行的監(jiān)控,包括了對(duì)Heap size和垃圾回收狀況的監(jiān)控??梢?jiàn),Jstat是輕量級(jí)的、專門針對(duì)JVM的工具,非常適用。
那,該怎么用呢?
??? 語(yǔ)法結(jié)構(gòu)如下:jstat [Options] vmid [interval] [count]
??? Options — 選項(xiàng),我們一般使用 -gcutil 查看gc情況
??? vmid??? — VM的進(jìn)程號(hào),即當(dāng)前運(yùn)行的java進(jìn)程號(hào)
??? interval– 間隔時(shí)間,單位為秒或者毫秒
??? count?? — 打印次數(shù),如果缺省則打印無(wú)數(shù)次
??? 下面給出一個(gè)實(shí)際的例子:
?
?
注:由于JVM內(nèi)存設(shè)置較大,圖中百分比變化不太明顯
?
??? 圖中參數(shù)含義如下:
??? S0 — Heap上的 Survivor space 0 區(qū)已使用空間的百分比
??? S1 — Heap上的 Survivor space 1 區(qū)已使用空間的百分比
??? E?? — Heap上的 Eden space 區(qū)已使用空間的百分比
??? O?? — Heap上的 Old space 區(qū)已使用空間的百分比
??? P?? — Perm space 區(qū)已使用空間的百分比
??? YGC — 從應(yīng)用程序啟動(dòng)到采樣時(shí)發(fā)生 Young GC 的次數(shù)
??? YGCT– 從應(yīng)用程序啟動(dòng)到采樣時(shí) Young GC 所用的時(shí)間(單位秒)
??? FGC — 從應(yīng)用程序啟動(dòng)到采樣時(shí)發(fā)生 Full GC 的次數(shù)
??? FGCT– 從應(yīng)用程序啟動(dòng)到采樣時(shí) Full GC 所用的時(shí)間(單位秒)
??? GCT — 從應(yīng)用程序啟動(dòng)到采樣時(shí)用于垃圾回收的總時(shí)間(單位秒)
??? 上圖的示例,紅框中,我們可以看到,5次young gc之后,垃圾內(nèi)存被從Eden space區(qū)(E)放入了Old space區(qū)(O),并引起了百分比的變化,導(dǎo)致Survivor space使用的百分比從19.69%(S0)降到10.34%(S1)。有效釋放了內(nèi)存空間。綠框中,我們可以看到,一次full gc之后,Old space區(qū)(O)的內(nèi)存被回收,從36.81%降到35.01%。
??? 圖中同時(shí)打印了young gc和full gc的總次數(shù)、總耗時(shí)。而,每次young gc消耗的時(shí)間,可以用相間隔的兩行YGCT相減得到。每次full gc消耗的時(shí)間,可以用相隔的兩行FGCT相減得到。例如紅框中表示的第一行、第二行之間發(fā)生了1次young gc,消耗的時(shí)間為52.281-52.252=0.029秒。
??? 常駐內(nèi)存區(qū)(P)的使用率,始終停留在37.6%左右,說(shuō)明常駐內(nèi)存沒(méi)有突變,比較正常。
如果young gc和full gc能夠正常發(fā)生,而且都能有效回收內(nèi)存,常駐內(nèi)存區(qū)變化不明顯,則說(shuō)明java內(nèi)存釋放情況正常,垃圾回收及時(shí),java內(nèi)存泄露的幾率就會(huì)大大降低。但也不能說(shuō)明一定沒(méi)有內(nèi)存泄露。
?
??? 以上,介紹了Jstat按百分比查看gc情況的功能。其實(shí),它還有其它功能,例如加載類信息統(tǒng)計(jì)功能、內(nèi)存池信息統(tǒng)計(jì)功能等,那些是以絕對(duì)值的形式打印出來(lái)的,比較少用,在此就不做介紹。
?
??? 為了更全面的監(jiān)控JVM內(nèi)存使用情況,我們需要引入更強(qiáng)大的工具來(lái)進(jìn)一步分析–JConsole。敬請(qǐng)關(guān)注。
--------
一、概述
??? SUN 的JDK中的幾個(gè)工具,非常好用。秉承著有免費(fèi),不用商用的原則。以下簡(jiǎn)單介紹一下這幾種工具。(注:本文章下的所有工具都存在JDK5.0以上版本的工具集里,同javac一樣,不須特意安裝) 。
????
??? 我一共找到以下四個(gè)工具:重點(diǎn)看看jconsole和jmap。
- 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ù)。并可通過(guò)遠(yuǎn)程連接監(jiān)視遠(yuǎn)程的服務(wù)器VM。??
?
二、 使用介紹:?
????
????
1、jstat
?:我想很多人都是用過(guò)unix系統(tǒng)里的ps命令,這個(gè)命令主要是用來(lái)顯示當(dāng)前系統(tǒng)的進(jìn)程情況,有哪些進(jìn)程,及其 id。 jps 也是一樣,它的作用是顯示當(dāng)前系統(tǒng)的java進(jìn)程情況,及其id號(hào)。我們可以通過(guò)它來(lái)查看我們到底啟動(dòng)了幾個(gè)java進(jìn)程(因?yàn)槊恳粋€(gè)java程序都會(huì)獨(dú)占一個(gè)java虛擬機(jī)實(shí)例),和他們的進(jìn)程號(hào)(為下面幾個(gè)程序做準(zhǔn)備),并可通過(guò)opt來(lái)查看這些進(jìn)程的詳細(xì)啟動(dòng)參數(shù)。?
??? 使用方法:在當(dāng)前命令行下打 jps(需要JAVA_HOME,沒(méi)有的話,到改程序的目錄下打) 。
可惜沒(méi)有l(wèi)inux下的ps好用,名稱不好用。但是在第四個(gè)工具jconsole的界面里面會(huì)有具體JAR包的名稱。
????
????
2、jstat
?:對(duì)VM內(nèi)存使用量進(jìn)行監(jiān)控。?
??? 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)題。
????
???
3、jmap?
是一個(gè)可以輸出所有內(nèi)存中對(duì)象的工具,甚至可以將VM 中的heap,以二進(jìn)制輸出成文本。使用方法 jmap -histo pid。如果連用 SHELL jmap -histo pid>a.log可以將其保存到文本中去(windows下也可以使用),在一段時(shí)間后,使用文本對(duì)比工具,可以對(duì)比出GC回收了哪些對(duì)象。jmap -dump:format=b,file=f1 3024可以將3024進(jìn)程的內(nèi)存heap輸出出來(lái)到f1文件里。?
????
??? 4、jconsole
?是一個(gè)用java寫的GUI程序,用來(lái)監(jiān)控VM,并可監(jiān)控遠(yuǎn)程的VM,非常易用,而且功能非常強(qiáng)。由于是GUI程序,這里就不詳細(xì)介紹了,不會(huì)的地方可以參考SUN的官方文檔。?
??? 使用方法:命令行里打 jconsole,選則進(jìn)程就可以了。?
????
??? 友好提示:windows查看進(jìn)程號(hào),由于任務(wù)管理器默認(rèn)的情況下是不顯示進(jìn)程id號(hào)的,所以可以通過(guò)如下方法加上。ctrl+alt+del打開(kāi)任務(wù)管理器,選擇‘進(jìn)程’選項(xiàng)卡,點(diǎn)‘查看’->''選擇列''->加上''PID'',就可以了。當(dāng)然還有其他很好的選項(xiàng)。
?
三、參考資料:
??? article:http://elf8848.javaeye.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?
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
