性能查看工具JProfiler,可用於查看java執行效率,查看線程狀態,查看內存佔用與內存對象,還能夠分析dump日誌.html
選擇attach to a locally running jvm java
選擇須要查看運行的jvm,雙擊或者點擊start windows
等待進度完成,彈出模式選擇 數組
點擊OK tomcat
選擇Live Momory能夠查看內存中的對象和大小 安全
選擇cpu views點擊下圖框中的按鈕來紀錄cpu的執行時間 bash
這時候能夠在外部對須要錄的jvm操做進行記錄了,得出的結果能夠輕鬆看出方法執行調用過程與消耗時間比例:網絡
根據cpu截圖的信息,能夠找到效率低的地方進行處理,若是是Instrumentation模式則在時間位置會顯示調用次數jvm
在Thread界面則能夠實時查看線程運行狀態,黃色的是wait 紅色是block 綠色的是runnable藍色是網絡和I/O請求狀態 工具
選擇ThreadDumps,能夠錄製瞬時線程的調用堆棧信息,以下圖所示:
當JProfiler鏈接到JVM以後選擇Heap Walker,選擇Take snapshot圖標,而後等待便可 若是內存很大,jprofiler萬一參數設置的不正確打不開就須要要從新生成,內存小的時候無所謂
當JProfiler鏈接到JVM以後選擇菜單上的Profiling->save HPROF snapshot 彈出下拉框保存便可,這時候生成的文件就能夠一直保存在文件上
jmap -dump:format=b,file=文件名 pid windows下不用[],路徑要加引號 jmap -dump:format=b,file="D:\a.dump" 8632
命令中文件名就是要保存的dump文件路徑, pid就是當前jvm進程的id
在發生outofmemory的時候自動生成dump文件:
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\heapdump
Pah後面是一個存在的可訪問的路徑,將改參數放入jvm啓動參數能夠在發生內存outofmemory的時候自動生成dump文件,可是正式環境使用的時候不要加這個參數,否則在內存快滿的時候老是會生成dump而致使jvm卡半天,須要調試的時候才須要加這個參數
注意:經過WAS生成的PHD文件dump不能分析出出問題的模板,由於PHD文件不包含對象的值內容,沒法根據PHD文件找到出問題的模板,因此PHD文件沒有太大的參考價值
dump文件生成後,將dump壓縮傳輸到本地,無論當前dump的後綴名是什麼,直接改爲*.hprof,就能夠直接用jprofiler打開了
打開的過程時間可能會很長,主要是要對dump進行預處理,計算什麼的,注意 這個過程不能點skip,不然就不太好定位大文件
.hprof
文件 也可使用工具欄中的「轉到開始」按鈕訪問第一個數據集
JProfiler的內存視圖部分能夠提供動態的內存使用情況更新視圖和顯示關於內存分配情況信息的視圖。全部的視圖都有幾個彙集層而且可以顯示現有存在的對象和做爲垃圾回收的對象。
在視圖中找到增加快速的對象類型,在memory視圖中找到Concurrenthashmap---點右鍵----選擇「Show Selectiion In Heap Walker」,切換到HeapWarker 視圖;切換前會彈出選項頁面,注意必定要選擇「Select recorded objects」,這樣Heap Walker會在剛剛的那段記錄中進行分析;不然,會分析tomcat的全部內存對象,這樣既耗時又不許確;
在JProfiler的堆遍歷器(Heap Walker)中,你能夠對堆的情況進行快照而且能夠經過選擇步驟下尋找感興趣的對象。堆遍歷器有五個視圖:
HeapWarker 會分析內存中的全部對象,包括對象的引用、建立、大小和數量. 經過切換到References頁籤,能夠看到這個類的具體對象實例。 爲了在這些內存對象中,找到泄漏的對象(應該被回收),能夠在該對象上點擊右鍵,選擇「Use Selected Instances」縮小對象範圍
References 能夠看到該對象的的引用關係,選項顯示引用的類型
選擇「Show In Graph」將引用關係使用圖形方式展示;
Show Paths To GC Root
,會找到引用的根節點 若是還不能定位內存泄露的地方,咱們能夠嘗試使用Allocations頁籤,該頁籤顯示對象是如何建立出來的; 咱們能夠從建立方法開始檢查,檢查全部用到該對象的地方,直到找到泄漏位置;
你須要在references視圖和biggest視圖手動添加對象到圖表,它能夠顯示對象的傳入和傳出引用,能方便的找到垃圾收集器根源。
tips:在工具欄點擊"Go To Start"可使堆內存從新計數,也就是回到初始狀態。
JProfiler 提供不一樣的方法來記錄訪問樹以優化性能和細節。線程或者線程組以及線程情況能夠被全部的視圖選擇。全部的視圖均可以彙集到方法、類、包或J2EE組件等不一樣層上。CPU視圖部分包括:
訪問樹 Call Tree 顯示一個積累的自頂向下的樹,樹中包含全部在JVM中已記錄的訪問隊列。JDBC,JMS和JNDI服務請求都被註釋在請求樹中。請求樹能夠根據Servlet和JSP對URL的不一樣須要進行拆分。 熱點 Hot Spots 顯示消耗時間最多的方法的列表。對每一個熱點都可以顯示回溯樹。該熱點能夠按照方法請求,JDBC,JMS和JNDI服務請求以及按照URL請求來進行計算。 訪問圖 Call Graph 顯示一個從已選方法、類、包或J2EE組件開始的訪問隊列的圖。 方法統計 Method Statistis 顯示一段時間內記錄的方法的調用時間細節。
JProfiler經過對線程歷史的監控判斷其運行狀態,並監控是否有線程阻塞產生,還能將一個線程所管理的方法以樹狀形式呈現。對線程剖析,JProfiler提供如下視圖:
線程歷史 Thread History 顯示一個與線程活動和線程狀態在一塊兒的活動時間表。 線程監控 Thread Monitor 顯示一個列表,包括全部的活動線程以及它們目前的活動情況。 線程轉儲 Thread Dumps 顯示全部線程的堆棧跟蹤。
JProfiler提供了不一樣的監控器視圖,以下所示:
當前鎖定圖表 Current Locking Graph 顯示JVM中的當前鎖定狀況。 當前監視器 Current Monitors 顯示當前正在等待或阻塞中的線程操做。 鎖定歷史圖表 Locking History Graph 顯示記錄在JVM中的鎖定歷史。 監控器歷史 Monitor History 顯示等待或者阻塞的歷史。 監控器使用統計 Monitor Usage Statistics 計算統計監控器監控的數據。
觀察JVM的內部狀態,JProfiler提供了不一樣的遙感勘測視圖,以下所示:
內存 Memory 顯示堆棧的使用情況和堆棧尺寸大小活動時間表。 記錄的對象 Recorded Objects 顯示一張關於活動對象與數組的圖表的活動時間表。 記錄的生產量 Recorded Throughput 顯示一段時間累計的JVM生產和釋放的活動時間表。 垃圾回收活動 GC Activity 顯示一張關於垃圾回收活動的活動時間表。 類 Classes 顯示一個與已裝載類的圖表的活動時間表。 線程 Threads 顯示一個與動態線程圖表的活動時間表。 CPU負載 CPU Load 顯示一段時間中CPU的負載圖表。