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

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

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

    隨筆-112  評論-73  文章-0  trackbacks-0

    轉自http://blog.csdn.net/roland101/archive/2008/03/16/2188585.aspx

    最近壓力測試和調優Liferay portal,所以需要找到一種工具,可以比較好的監測VM工具。本來想使用商用工具,但偶然間發現SUN 的JDK中新添了幾個工具,并且非常好用。秉承著有免費,不用商用的原則。開始使用新的JDK工具,以下簡單介紹一下這幾種工具。(注:本文章下的所有工具都存在JDK5.0以上版本的工具集里,同javac一樣,不須特意安裝)

    我一共找到以下五個工具:
    jinfo:可以輸出并修改運行時的java 進程的opts。
    jps:與unix上的ps類似,用來顯示本地的java進程,可以查看本地運行著幾個java程序,并顯示他們的進程號。
    jstat:一個極強的監視VM內存工具。可以用來監視VM內存內的各種堆和非堆的大小及其內存使用量。
    jmap:打印出某個java進程(使用pid)內存內的,所有'對象'的情況(如:產生那些對象,及其數量)。
    jconsole:一個java GUI監視工具,可以以圖表化的形式顯示各種數據。并可通過遠程連接監視遠程的服務器VM。

    接下來是對這些工具的詳細介紹:

    從最簡單的jstat工具開始:我想很多人都是用過unix系統里的ps命令,這個命令主要是用來顯示當前系統的進程情況,有哪些進程,及其id。jps 也是一樣,它的作用是顯示當前系統的java進程情況,及其id號。我們可以通過它來查看我們到底啟動了幾個java進程(因為每一個java程序都會獨占一個java虛擬機實例),和他們的進程號(為下面幾個程序做準備),并可通過opt來查看這些進程的詳細啟動參數。
    使用方法:在當前命令行下打 jps(需要JAVA_HOME,沒有的話,到改程序的目錄下打)

    接下來是jstat,我之所以這次調優Liferay portal是因為,liferay在默認的情況下,并發用戶一多就會產生perm out of momery異常。雖然很開就解決了,但發現對VM內存使用量監控的重要性。通過google,很快的發現了jstat這個工具。
    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每三行顯示一下標題。

    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程序,用來監控VM,并可監控遠程的VM,非常易用,而且功能非常強。由于是GUI程序,這里就不詳細介紹了,不會的地方可以參考SUN的官方文檔。
    使用方法:命令行里打 jconsole,選則進程就可以了。

    以下是這些工具的SUN官方說明:
    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

    附加:windows查看進程號,由于任務管理器默認的情況下是不顯示進程id號的,所以可以通過如下方法加上。ctrl+alt+del打開任務管理器,選擇'進程'選項卡,點'查看'->'選擇列'->加上'PID',就可以了。

    posted on 2008-11-25 21:14 Libo 閱讀(471) 評論(0)  編輯  收藏 所屬分類: 其他
    主站蜘蛛池模板: 搜日本一区二区三区免费高清视频| 亚洲午夜在线电影| 亚洲av日韩专区在线观看| 亚洲高清视频免费| 亚洲系列中文字幕| 91精品视频免费| 亚洲人成777在线播放| 成人av免费电影| 豆国产96在线|亚洲| 亚洲国产天堂久久综合| 国产免费区在线观看十分钟 | 四虎成人免费大片在线| 亚洲最大中文字幕无码网站| 成年男女免费视频网站| 亚洲av无码片vr一区二区三区 | 免费人成在线视频| 亚洲AV无码一区二区三区牲色| 国产免费AV片无码永久免费| 亚美影视免费在线观看| 亚洲国产高清人在线| 又黄又爽又成人免费视频| 色偷偷尼玛图亚洲综合| 中文字幕人成人乱码亚洲电影| 日韩人妻无码精品久久免费一 | 久久久www成人免费毛片| 亚洲爆乳无码专区www| JLZZJLZZ亚洲乱熟无码| 嫩草成人永久免费观看| 亚洲香蕉久久一区二区| 亚洲国产成人私人影院| 岛国av无码免费无禁网站| 国产精品久久久久久亚洲影视| 亚洲中文字幕无码永久在线| 18女人腿打开无遮掩免费| 色屁屁在线观看视频免费| 亚洲成A人片在线观看无码不卡| 在线永久免费的视频草莓| 永久免费精品影视网站| 亚洲国产精品成人久久久| 国产精品亚洲视频| 免费成人激情视频|