JProfiler 使用說明

一個全功能的 Java 剖析工具( profiler ),專用於分析 J2SE 和 J2EE 應用程序。它把 CPU 、執行緒和內存的剖析組合在一個強大的 應用中。 JProfiler 可提供許多 IDE 整合和應用服務器整合用途。 JProfiler 直覺式的 GUI 讓你能夠找到效能瓶頸、抓出內存漏失 (memory leaks) 、並解決執行緒的問題。它讓你得以對 heap walker 做資源回收器的 root analysis ,能夠輕易找出內存溢出; heap 快照( snapshot )模式讓未被參照( reference )的對象、稍微被參照的對象、或在終結( finalization )隊列的對象 都會被移除;整合精靈以便剖析瀏覽器的 Java 外掛功能。數組

 

目前最新的版本是 6.0 ,幾乎支持全部經常使用的 IDE 和 Application Server ,能夠到其 EJ 官方網站 http://www.ej-technologies.com/ 下載。瀏覽器

5 、 JProfiler 特徵

5.1 內存剖析 Memory profiler

JProfiler 的內存視圖部分能夠提供動態的內存使用情況更新視圖和顯示關於內存分配情況信息的視圖。全部的視圖都有幾個彙集層而且可以顯示現有存在的對象和做爲垃圾回收的對象。服務器

  • 全部對象 顯示類或在情況統計和尺碼信息堆上全部對象的包。你能夠標記當前值並顯示差別值。
  • 記錄對象 Record objects 顯示類或全部已記錄對象的包。你能夠標記出當前值而且顯示差別值。
  • 分配訪問樹 Allocation call tree 顯示一棵請求樹或者方法、類、包或對已選擇類有帶註釋的分配信息的J2EE組件。
  • 分配熱點 Allocation hot spots 顯示一個列表,包括方法、類、包或分配已選類的J2EE組件。你能夠標註當前值而且顯示差別值。對於每一個熱點均可以顯示它的跟蹤記錄樹。

5.2 堆遍歷 Heap walker

在JProfiler的堆遍歷器(Heap walker)中,你能夠對堆的情況進行快照而且能夠經過選擇步驟下尋找感興趣的對象。堆遍歷器有五個視圖:工具

  • 類 Classes 顯示全部類和它們的實例。
  • 分配 Allocations 爲全部記錄對象顯示分配樹和分配熱點。
  • 索引 References 爲單個對象和「顯示到垃圾回收根目錄的路徑」提供索引圖的顯示功能。還能提供合併輸入視圖和輸出視圖的功能。
  • 數據 Data 爲單個對象顯示實例和類數據。
  • 時間 Time 顯示一個對已記錄對象的解決時間的柱狀圖。

5.3 CPU 剖析 CPU profiler

JProfiler 提供不一樣的方法來記錄訪問樹以優化性能和細節。線程或者線程組以及線程情況能夠被全部的視圖選擇。全部的視圖均可以彙集到方法、類、包或J2EE組件等不一樣層上。CPU視圖部分包括:性能

  • 訪問樹 Call tree 顯示一個積累的自頂向下的樹,樹中包含全部在JVM中已記錄的訪問隊列。JDBC,JMS和JNDI服務請求都被註釋在請求樹中。請求樹能夠根據Servlet和JSP對URL的不一樣須要進行拆分。
  • 熱點 Hot spots 顯示消耗時間最多的方法的列表。對每一個熱點都可以顯示回溯樹。該熱點能夠按照方法請求,JDBC,JMS和JNDI服務請求以及按照URL請求來進行計算。
  • 訪問圖 Call graph 顯示一個從已選方法、類、包或J2EE組件開始的訪問隊列的圖。

5.4 線程剖析 Thread profiler

對線程剖析,JProfiler提供如下視圖:優化

  • 線程歷史 Thread history 顯示一個與線程活動和線程狀態在一塊兒的活動時間表。
  • 線程監控 Thread monitor 顯示一個列表,包括全部的活動線程以及它們目前的活動情況。
  • 死鎖探測圖表 Deadlock Detection 顯示一個包含了全部在JVM裏的死鎖圖表。
  • 目前使用的監測器 Current monitor useage 顯示目前使用的監測器而且包括它們的關聯線程。
  • 歷史檢測記錄 History usage history 顯示重大的等待事件和阻塞事件的歷史記錄。
  • 監測使用狀態 Monitor usage statistics 顯示分組監測,線程和監測類的統計監測數據。

5.5 VM 遙感勘測技術 VM telemetry

觀察JVM的內部狀態,JProfiler提供了不一樣的遙感勘測視圖,以下所示:網站

  • 堆 Heap 顯示一個堆的使用情況和堆尺寸大小活動時間表。
  • 記錄的對象 Recorded objects 顯示一張關於活動對象與數組的圖表的活動時間表。
  • 垃圾回收 Garbage collector 顯示一張關於垃圾回收活動的活動時間表。
  • 類 Classes 顯示一個與已裝載類的圖表的活動時間表。
  • 線程 Threads 顯示一個與動態線程圖表的活動時間表。
相關文章
相關標籤/搜索