JVM:查看java內存狀況命令

  jmap (linux下特有,也是很經常使用的一個命令)java

  觀察運行中的jvm物理內存的佔用狀況。linux

  參數以下:緩存

  -heap :打印jvm heap的狀況服務器

  -histo: 打印jvm heap的直方圖。其輸出信息包括類名,對象數量,對象佔用大小。less

  -histo:live : 同上,可是隻答應存活對象的狀況jvm

  -permstat: 打印permanent generation heap狀況工具

  命令使用:spa

  jmap -heap 3409命令行

  能夠觀察到New Generation(Eden Space,From Space,To Space),tenured generation,Perm Generation的內存使用狀況線程

  輸出內容:

  jmap -histo 3409 | jmap -histo:live 3409

  能夠觀察heap中全部對象的狀況(heap中全部生存的對象的狀況)。包括對象數量和所佔空間大小。

  輸出內容:

  寫個腳本,能夠很快把佔用heap最大的對象找出來,對付內存泄漏特別有效。

  若是結果不少,能夠用如下命令輸出到文本文件。

  jmap -histo 3409 | jmap -histo:live 3409 > a.txt

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

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

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

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

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

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

  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 -dump:format=b,file=heap.bin

  file:保存路徑及文件名

  pid:進程編號

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

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

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

  jconsole是一個用java寫的GUI程序,用來監控VM,並可監控遠程的VM,很是易用,並且功能很是強。使用方法:命令行裏打 jconsole,選則進程就能夠了。

  JConsole中關於內存分區的說明。

  Eden Space (heap): 內存最初從這個線程池分配給大部分對象。

  Survivor Space (heap):用於保存在eden space內存池中通過垃圾回收後沒有被回收的對象。

  Tenured Generation (heap):用於保持已經在 survivor space內存池中存在了一段時間的對象。

  Permanent Generation (non-heap): 保存虛擬機本身的靜態(refective)數據,例如類(class)和方法(method)對象。Java虛擬機共享這些類數據。這個區域被分割爲只讀的和只寫的,

  Code Cache (non-heap):HotSpot Java虛擬機包括一個用於編譯和保存本地代碼(native code)的內存,叫作「代碼緩存區」(code cache)

  ?jstack ( 查看jvm線程運行狀態,是否有死鎖現象等等信息) : jstack pid : thread dump

  ?jstat -gcutil pid 1000 100 : 1000ms統計一次gc狀況統計100次;

  另外推薦一款查看jmap dump 的內存對象工具 MemoryAnalyzer

相關文章
相關標籤/搜索