Windows查看Java內存使用情況

目錄

1. 場景

2.  jconsole使用

3. jconsole和任務管理器配合查看內存

4. Windows自帶Java內存查看工具以及命令

 5. 總結


1. 場景

有時候我們啓動了多個java程序,需要查看各個java程序佔用的的內存情況。

打開任務管理器選擇“進程”,發現有好多java.exe進程,無法直接查看內存使用情況。

jconsole定義:jconsole是一個用java寫的GUI程序,用來監控VM,並可監控遠程的VM,非常易用,而且功能非常強 。

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

2.  jconsole使用

1) 在cmd命令窗口輸入 jconsole ,彈出Java監視和管理控制檯窗口

2) 選擇本地進程,可根據進程名稱或者進程ID ( pid ) 查看內存情況

或者可以根據  netstat -ano | findstr 8080   (端口號是你的程序正在使用的port )得到進程ID

3) 舉例:這裏我想查看Elasticsearch內存使用情況,進程ID爲11544

4) 點擊連接,如下圖所示:

3. jconsole和任務管理器配合查看內存

如果我們不清楚根據哪一個端口查看進程PID,可使用以下方法。

1) 根據jconsole彈出的Java監視和管理控制檯窗口,可以根據名稱得到需要查看的進程PID

2) 打開任務管理器--性能--資源監視器,選擇對應進程PID查看內存、CPU使用情況,這裏,我以查看ES進程爲例,PID爲11544,如下圖所示:

4. Windows自帶Java內存查看工具以及命令

工具:

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

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

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

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

jconsole:一個java GUI監視工具,可以以圖表化的形式顯示各種數據。並可通過遠程連接監視遠程的服務器VM。 
 

命令詳解:

詳細:在使用這些工具前,先用JPS命令獲取當前的每個JVM進程號,然後選擇要查看的JVM。 

1) 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每三行顯示一下標題。 
 

2) jmap是一個可以輸出所有內存中對象的工具,甚至可以將VM 中的heap,以二進制輸出成文本。 

命令:jmap -dump:format=b,file=heap.bin <pid> 

說明:file:保存路徑及文件名,pid:進程編號 

jmap -histo:live  pid| less:堆中活動的對象以及大小 

jmap -heap pid :查看堆的使用狀況信息 

3) jinfo的用處比較簡單,就是能輸出並修改運行時的java進程的運行參數。

用法是jinfo -opt pid     如:查看2788的MaxPerm大小可以用 jinfo -flag MaxPermSize 2788。 

4) jconsole是一個用java寫的GUI程序,用來監控VM,並可監控遠程的VM,非常易用,而且功能非常強。

使用方法:命令行裏打 jconsole,選擇進程查看。

另外推薦一款查看jmap dump 的內存對象工具 MemoryAnalyzer ,官網,可以查看dump時對象數量,內存佔用,線程情況等。

 5. 總結

我們可以根據Windows自帶的工具查看內存、gc情況,檢測處理Java內存泄漏。

 

 

 

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