JVM內存監控

  1. jinfo:可以輸出並修改運行時的java 進程的opts。     
  2. jps: 與unix上的ps類似,用來顯示本地的java進程,可以查看本地運行着幾個java程序,並顯示他們的進程號。     
  3. jstat: 一個極強的監視VM內存工具。可以用來監視VM內存內的各種堆和非堆的大小及其內存使用量。     
  4. jmap: 打印出某個java進程(使用pid)內存內的,所有‘對象’的情況(如:產生那些對象,及其數量)。     
  5. jconsole: 一個java GUI監視工具,可以以圖表化的形式顯示各種數據。並可通過遠程連接監視遠程的服務器VM。     
  6.     
  7. 接 下來是對這些工具的詳細介紹:     
  8.     
  9. 從最簡單的 jstat工具開始:我想很多人都是用過unix系統裏的ps命令,這個命令主要是用來顯示當前系統的進程情況,有哪些進程,及其id。jps 也是一 樣,它的作用是顯示當前系統的java進程情況,及其id號。我們可以通過它來查看我們到底啓動了幾個java進程(因爲每一個java程序都會獨佔一個 java虛擬機實例),和他們的進程號(爲下面幾個程序做準備),並可通過opt來查看這些進程的詳細啓動參數。     
  10. 使 用方法:在當前命令行下打 jps(需要JAVA_HOME,沒有的話,到改程序的目錄下打)     
  11.     
  12. 接 下來是jstat,我之所以這次調優Liferay portal是因爲,liferay在默認的情況下,併發用戶一多就會產生 perm out of momery異常。雖然很開就解決了,但發現對VM內存使用量監控的重要性。通過google,很快的發現了jstat這個工 具。     
  13. jstat工具特別強大,有衆多的可選項,詳細查看堆內各個部分的使用量,以及加載類的數 量。使用時,需加上查看進程的進程id,和所選參數。以下詳細介紹各個參數的意義。     
  14. jstat -class  pid:顯示加載 class 的 數量,及所佔空間等信息。     
  15. jstat -compiler pid:顯示VM實時 編譯的數量等信息。     
  16. jstat -gc pid:可以顯示gc的信息,查看gc的次數,及時間。 其中最後五項,分別是young gc的次數,young gc的時間,full gc的次數,full gc的時間,gc的總時間。     
  17. jstat -gccapacity: 可以顯示,VM內存中三代(young,old,perm)對象的使用和佔用大小,如:PGCMN顯示的是最小perm的內存使用量,PGCMX顯示的是 perm的內存最大使用量,PGC是當前新生成的perm內存佔用量,PC是但前perm內存佔用量。其他的可以根據這個類推, OC是old內純的佔用 量。     
  18. jstat -gcnew pid:new 對 象的信息。     
  19. jstat -gcnewcapacity pid:new 對象的信息及其佔用量。     
  20. jstat -gcold pid:old 對象的信息。     
  21. jstat -gcoldcapacity pid:old對象的信息及其佔用 量。     
  22. jstat -gcpermcapacity pid: perm對象的信息及其佔用 量。     
  23. jstat -util pid:統計gc信息統計。     
  24. jstat -printcompilation pid: 當前VM執行的信息。     
  25. 除了以上一個參數外,還可以同時加上 兩個數字, 如:jstat -printcompilation 3024   250   6 是 每 250 毫秒打印一次,一共打印 6 次,還可以加上-h3每三行顯示一下標題。     
  26.     
  27. jmap 是一個可以輸出所有內存中對象的工具,甚至可以將VM 中的heap,以二進制輸出成文本。使用方法 jmap -histo pid。如果連用 SHELL jmap -histo pid>a.log可以將其保存到文本中去,在一段時間後,使用文本對比工具,可以對比出GC回收了哪些對 象。jmap -dump:format=b,file=String 3024 可 以將 3024 進程的內存heap輸出出來到String文件 裏。     
  28.     
  29. jinfo:的用處比 較簡單,就是能輸出並修改運行時的java進程的運行參數。用法是jinfo -opt pid 如:查看2788 的 MaxPerm大小可以用 jinfo -flag MaxPermSize  2788 。     
  30.     
  31. jconsole 是一個用java寫的GUI程序,用來監控VM,並可監控遠程的VM,非常易用,而且功能非常強。由於是GUI程序,這裏就不詳細介紹了,不會的地方可以 參考SUN的官方文檔。     
  32. 使用方法:命令行裏打 jconsole,選則進程就可以了。     
  33.     
  34. 以 下是這些工具的SUN官方說明:     
  35. jps:http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/jps.html      
  36. jstat:http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/jstat.html      
  37. jmap:http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/jmap.html      
  38. jconsole:http://java.sun.com/j2se/1.5.0/docs/guide/management/jconsole.html      
  39.     
  40. 附 加:windows查看進程號,由於任務管理器默認的情況下是不顯示進程id號的,所以可以通過如下方法加上。ctrl+alt+del打開任務管理器, 選擇‘進程’選項卡,點‘查看’->'選擇列' ->加上 'PID' ,就可以了。   

Jstat介紹:
用以判斷JVM是否存在內存問題呢?如何判斷JVM垃圾回收是否正常?一般的top指令基本上滿足不了這樣的需求,因爲它主要監控的是總體的系統資源,很難定位到java應用程序。

Jstat是JDK自帶的一個輕量級小工具。全稱“Java Virtual Machine statistics monitoring tool”,它位於java的bin目錄下,主要利用JVM內建的指令對Java應用程序的資源和性能進行實時的命令行的監控,包括了對Heap size和垃圾回收狀況的監控。可見,Jstat是輕量級的、專門針對JVM的工具,非常適用。由於JVM內存設置較大,圖中百分比變化不太明顯

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

jstat工具特別強大,有衆多的可選項,詳細查看堆內各個部分的使用量,以及加載類的數量。使用時,需加上查看進程的進程id,和所選參數。

執行:cd $JAVA_HOME/bin中執行jstat,注意jstat後一定要跟參數。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章