1、概述
SUN 的JDK中的幾個工具,很是好用。秉承着有免費,不用商用的原則。如下簡單介紹一下這幾種工具。(注:本文章下的全部工具都存在JDK5.0以上版本的工具集裏(jdk的bin目錄下),同Javac同樣,不須特地安裝直接雙擊打開) 。
我一共找到如下四個工具:重點看看jconsole和jmap。
1.jps
與unix上的ps相似,用來顯示本地的java進程,能夠查看本地運行着幾個java程序,並顯示他們的進程號。
2.jstat
一個極強的監視VM內存工具。能夠用來監視VM內存內的各類堆和非堆的大小及其內存使用量。
3.jmap
打印出某個java進程(使用pid)內存內的,全部‘對象’的狀況(如:產生那些對象,及其數量)。
4.jconsole
一個java GUI監視工具,能夠以圖表化的形式顯示各類數據。並可經過遠程鏈接監視遠程的服務器VM。
2、 使用介紹:
一、jstat :我想不少人都是用過unix系統裏的ps命令,這個命令主要是用來顯示當前系統的進程狀況,有哪些進程,及其 id。 jps 也是同樣,它的做用是顯示當前系統的java進程狀況,及其id號。咱們能夠經過它來查看咱們到底啓動了幾個java進程(由於每個java程序都會獨佔一個java虛擬機實例),和他們的進程號(爲下面幾個程序作準備),並可經過opt來查看這些進程的詳細啓動參數。
使用方法:在當前命令行下打 jps(須要JAVA_HOME,沒有的話,到改程序的目錄下打) 。
惋惜沒有Linux下的ps好用,名稱很差用。可是在第四個工具jconsole的界面裏面會有具體JAR包的名稱。
二、jstat :對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 pidld對象的信息。
jstat -gcoldcapacity pidld對象的信息及其佔用量。
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能夠將其保存到文本中去(windows下也可使用),在一段時間後,使用文本對比工具,能夠對比出GC回收了哪些對象。jmap -dump:format=b,file=f1 3024能夠將3024進程的內存heap輸出出來到f1文件裏。
四、jconsole 是一個用java寫的GUI程序,用來監控VM,並可監控遠程的VM,很是易用,並且功能很是強。因爲是GUI程序,這裏就不詳細介紹了,不會的地方能夠參考SUN的官方文檔。
使用方法:命令行裏打 jconsole,選則進程就能夠了。
友好提示:windows查看進程號,因爲任務管理器默認的狀況下是不顯示進程id號的,因此能夠經過以下方法加上。ctrl+alt+del打開任務管理器,選擇‘進程’選項卡,點‘查看’->''選擇列''->加上''PID'',就能夠了。固然還有其餘很好的選項。html