<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    我的java天地

    jstat,jmap,jconsole,jvisualvm,jps,jinfo等JDK系統(tǒng)監(jiān)控、性能調優(yōu)工具

    @import url(http://www.tkk7.com/CuteSoft_Client/CuteEditor/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/css/cuteeditor.css); @import url(http://www.tkk7.com/CuteSoft_Client/CuteEditor/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/css/cuteeditor.css);
    jmap -heap:format=b pid   bin格式  javaversion 1.5
    jmap -dump:format=b,file=filename pid javaversion >1.6


    工具名稱:IBM HeapAnalyzer

    JProfiler在java程序性能調試方便表現(xiàn)優(yōu)越,推薦使用。也可使用下面jdk自己的一些工具。

    所有工具都在JDK/bin目錄下, jconsole和jvisualvm為GUI圖形化工具,其他為命令行。

    jvisualvm: GUI工具,可監(jiān)控、性能評估、故障診斷主機上所有java進程的cpu,內存,線程使用情況,類似于JProfiler,嚴重推薦。

    jinfo:可以輸出并修改運行時的java 進程的opts。

    jps:與unix上的ps類似,用來顯示本地的java進程,可以查看本地運行著幾個java程序,并顯示他們的進程號。

    jstat:一個極強的監(jiān)視VM內存工具。可以用來監(jiān)視VM內存內的各種堆和非堆的大小及其內存使用量。

    jmap:打印出某個java進程(使用pid)內存內的,所有‘對象’的情況(如:產生那些對象,及其數量)。

    jconsole:一個java GUI監(jiān)視工具,可以以圖表化的形式顯示各種數據。并可通過遠程連接監(jiān)視遠程的服務器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:統(tǒng)計gc信息統(tǒng)計。
    jstat -printcompilation pid:當前VM執(zhí)行的信息。
    除了以上一個參數外,還可以同時加上 兩個數字,如:jstat -printcompilation 3024 250 6是每250毫秒打印一次,一共打印6次,還可以加上-h3每三行顯示一下標題。

    jmap是一個可以輸出所有內存中對象的工具,甚至可以將VM 中的heap,以二進制輸出成文本。使用方法 jmap -histo pid。如果連用SHELL jmap -histo pid>a.log可以將其保存到文本中去,在一段時間后,使用文本對比工具,可以對比出GC回收了哪些對象。jmap -dump:format=b,file=String 3024可以將3024進程的內存heap輸出出來到String文件里。

    jinfo:的用處比較簡單,就是能輸出并修改運行時的java進程的運行參數。用法是jinfo -opt  pid 如:查看2788的MaxPerm大小可以用  jinfo -flag MaxPermSize 2788。

    jconsole是一個用java寫的GUI程序,用來監(jiān)控VM,并可監(jiān)控遠程的VM,非常易用,而且功能非常強。由于是GUI程序,這里就不詳細介紹了,不會的地方可以參考SUN的官方文檔。
    使用方法:命令行里打 jconsole,選則進程就可以了。

    SUN官方說明:

    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老是內存撐到頭,然后崩潰的問題時,使用到了jmap。
    1 使用命令
    在環(huán)境是linux+jdk1.5以上,這個工具是自帶的,路徑在JDK_HOME/bin/下
    jmap -histo pid>a.log

    2 輸出結果摘要
    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和自定義對象com.test.util.IPSeeker$IPLocation存在,檢查程序發(fā)現(xiàn)此處果然存在內存溢出。修改程序上線后再次用jmap抓取內存數據:

    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

    內存溢出問題消除。
    注意:這個jmap使用的時候jvm是處在假死狀態(tài)的,只能在服務癱瘓的時候為了解決問題來使用,否則會造成服務中斷。



    @import url(http://www.tkk7.com/CuteSoft_Client/CuteEditor/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/css/cuteeditor.css);

    posted on 2012-02-07 17:02 tobyxiong 閱讀(2254) 評論(0)  編輯  收藏 所屬分類: java

    <2012年2月>
    2930311234
    567891011
    12131415161718
    19202122232425
    26272829123
    45678910

    導航

    統(tǒng)計

    常用鏈接

    留言簿(3)

    隨筆分類(144)

    隨筆檔案(157)

    相冊

    最新隨筆

    搜索

    積分與排名

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 国产国产人免费人成成免视频| 亚洲av日韩av无码黑人| 暖暖在线日本免费中文| 亚欧色视频在线观看免费| 日韩精品无码一区二区三区免费 | 亚洲AV中文无码字幕色三| 中文字幕亚洲图片| 国产亚洲美女精品久久久| 久久亚洲中文字幕精品一区| 亚洲中文字幕在线观看| 国产av无码专区亚洲av桃花庵| 亚洲AV乱码久久精品蜜桃| 亚洲日本在线观看| 亚洲一区二区三区亚瑟| 亚洲av成人综合网| 九九精品国产亚洲AV日韩| 特黄特色的大片观看免费视频| yellow视频免费看| 免费视频精品一区二区三区| 91在线手机精品免费观看| 日韩一区二区a片免费观看| 色视频色露露永久免费观看| 亚洲 综合 国产 欧洲 丝袜| 亚洲色婷婷综合久久| 亚洲视频在线观看一区| 亚洲伊人久久大香线蕉影院| 亚洲JIZZJIZZ妇女| a毛片成人免费全部播放| 蜜桃成人无码区免费视频网站 | 人禽杂交18禁网站免费| 国产成人啪精品视频免费网| 国产国拍亚洲精品福利| 亚洲国产成人精品不卡青青草原| 亚洲性色高清完整版在线观看| 亚洲一卡2卡3卡4卡5卡6卡| 曰韩无码AV片免费播放不卡| 久久大香香蕉国产免费网站| 永久免费AV无码国产网站| 亚洲国产人成中文幕一级二级| 亚洲AV无码乱码国产麻豆| 亚洲永久在线观看|