JProfiler是惟一一款獲過獎的Java剖析器。JProfiler直觀的用戶界面可以幫助你找到性能瓶頸,並指明你的內存漏洞和解決線程問題。
JProfiler's 特徵:數組
- 內存剖析
JProfiler的內存視圖部分能夠提供動態的內存使用情況更新視圖和顯示關於內存分配情況信息的視圖。全部的視圖都有幾個彙集層而且可以顯示現有存在的對象和做爲垃圾回收的對象。
- 全部對象
顯示類或在情況統計和尺碼信息堆上全部對象的包。你能夠標記當前值並顯示差別值。
- 記錄對象
顯示類或全部已記錄對象的包。你能夠標記出當前值而且顯示差別值。
- 分配請求樹
顯示一棵請求樹或者方法、類、包或對已選擇類有帶註釋的分配信息的J2EE組件。
- 分配熱點
顯示一個列表,包括方法、類、包或分配已選類的J2EE組件。你能夠標註當前值而且顯示差別值。對於每一個熱點均可以顯示它的跟蹤記錄樹。
- 堆遍歷
在JProfiler的堆遍歷器中,你能夠對堆的情況進行快照而且能夠經過選擇步驟下尋找感興趣的對象。堆遍歷器有五個視圖:
- 類
顯示全部類和它們的實例。
- 分配
爲全部記錄對象顯示分配樹和分配熱點。
- 索引
爲單個對象和「顯示到垃圾回收根目錄的路徑」提供索引圖的顯示功能。還能提供合併輸入視圖和輸出視圖的功能。
- 數據
爲單個對象顯示實例和類數據。
- 時間
顯示一個對已記錄對象的解決時間的柱狀圖。
- CPU剖析器
JProfiler提供不一樣的方法來記錄請求樹以優化性能和細節。線程或者線程組以及線程情況能夠被全部的視圖選擇。全部的視圖均可以彙集到方法、類、包或J2EE組件等不一樣層上。CPU視圖部分包括:
- 請求樹
顯示一個積累的自頂向下的樹,樹中包含全部在JVM中已記錄的請求隊列。JDBC,JMS和JNDI服務請求都被註釋在請求樹中。請求樹能夠根據servlet和JSP對URL的不一樣須要進行拆分。
- 熱點
顯示消耗時間最多的方法的列表。對每一個熱點都可以顯示回溯樹。該熱點能夠按照方法請求,JDBC,JMS和JNDI服務請求以及按照URL請求來進行計算。
- 請求圖
顯示一個從已選方法、類、包或J2EE組件開始的請求隊列的圖。
- 線程剖析
對線程剖析,JProfiler提供如下視圖:
- 線程歷史
顯示一個與線程活動和線程狀態在一塊兒的活動時間表.
- 線程監控
顯示一個列表,包括全部的活動線程以及它們目前的活動情況。
- 固定探測圖表
顯示一個包含了全部在JVM裏的固定的圖表。
- 目前使用的監測器
顯示目前使用的監測器而且包括它們的關聯線程。
- 歷史檢測記錄
顯示重大的等待事件和阻塞事件的歷史記錄。
- 監測使用狀態
顯示分組監測,線程和監測類的統計監測數據。
- VM 遙感勘測技術
觀察JVM的內部狀態,JProfiler提供了不一樣的遙感勘測視圖,以下所示:
- 堆
顯示一個堆的使用情況和堆尺寸大小活動時間表。
- 對象
顯示一張關於活動對象與數組的圖表的活動時間表。
- Garbage collector
顯示一張關於垃圾回收活動的活動時間表。
- 類
顯示一個與已裝載類的圖表的活動時間表。
- 線程顯示一個與動態線程圖表的活動時間表。