jdk自帶監控程序jvisualvm的使用

  1. 監控小程序的配置
  1. 生產環境tomcat的配置

編輯應用所在的tomcat服務器下的bin目錄下的catalina.sh文件,修改如下:

配置如下內容:

export JAVA_OPTS="-Xms256m -Xmx512m -Xss256m -XX:PermSize=512m -XX:MaxPermSize=1024m  -Djava.rmi.server.hostname=136.64.45.24 -Dcom.sun.management.jmxremote.port=9315 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false"

紅字內容需要進行添加,黃色背景的需要根據具體的主機情況配置。

  1. 本地jdk小工具的配置

進入到本地的jdk安裝目錄下,找到jvisualvm.exe,雙擊打開

 

建立遠程連接

圖一 添加遠程

圖二 建立遠程主機ip

 

圖三 添加jmx連接

圖四 雙擊建立好的連接可以實時查看當前程序的運行狀況和堆棧信息等

         監控小程序菜單截圖

圖一 概述:顯示當前tomcat服務器的整體運行狀況

圖二:可事實動態顯示cpu、堆棧、類、線程的相關信息

圖三:線程:可實時動態的顯示進程的使用狀況

點擊線程Dump按鈕可以顯示具體的進程的內容,可從此頁面查看到進程的具體信息以及報錯信息

(4)通過此工具的使用,當ITSM系統僵死時,可看到明顯的進程變化

a.所有的請求進程都進入了監控狀態,所有請求都無法訪問

          

  1. 查看dump信息,發現ITSM系統首頁的報表獲取sql存在問題,訪問量增多時,打開首頁查詢比較慢,鏈接釋放緩慢,然後新增請求,導致鏈接池被沾滿,出現了上述問題。

  1. 故障解決方案

通過上述分析,查看連接池配置,對連接池的活動連接數和空閒連接數做了調賬,如下圖:

同時找到對應的sql語句進行優化,之前的sql存在笛卡爾積,同時數據量大,沒有建立索引,通過dba的分析修改了sql語句,並對timeouttime字段建立索引,截圖如下(包含原有sql【被註釋了】)

  1. 知識擴展

Jdk自帶的監控小工具可用來對java程序進行調優和問題分析。

應用僵死後是否有dump或javacore文件生成?拿到後用MemoryAnalyzer 工具分析一下

如果沒有,可以用jdk自帶的小工具看一下,是否有資源未釋放、線程死鎖、內存溢出等問題

 

============================================================

jstack ( 查看jvm線程運行狀態,是否有死鎖現象等等信息)
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內存佔用量。其他的可以根據這個類推, OCold內純的佔用量。 
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 <pid> 
file
:保存路徑及文件名 
pid
:進程編號 
•jmap -histo:live  pid| less :
堆中活動的對象以及大小 
•jmap -heap pid :
查看堆的使用狀況信息 


jinfo:
的用處比較簡單,就是能輸出並修改運行時的java進程的運行參數。用法是jinfo -opt pid 如:查看2788MaxPerm大小可以用 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次; 

 

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