Java幾款性能分析工具的對比
在給客戶進行應用程序維護的過程中,我注意到一些關于高負載條件下的性能問題。 理論上,增加對應用程序的負載會使性能有所下降,但是我認為性能下降的比率遠遠高于負載的增加,同時我也發現,性能可以通過改變應用程序的邏輯來提升。為 了更詳細地了解這一點,我們需要做一些性能分析,這時,我們自然就要用到一些性能分析工具。Java有許多的性能分析工具,可以幫助我們弄清楚這個問題, 但是我們應該使用哪一款工具呢?
為了做出正確的選擇,我列出性能分析應滿足一些最低要求:
- 必須包括對應用程序的類、方法及時間的監測
- 必須包括對內存的監測
- 必須具有易用性
我配置了一個使用RESTful接口的Spring應用程序,使用MongoDB作為數據存儲,還使用Solr搜索,并在Tomcat服務器上部署。
參考工具:
1.VisualVM
VisualVM是一個資源分析工具,一直從JDK 6更新到7,它默認內存和CPU的監視,它可以告訴你哪個類和方法消耗資源,但它不會顯示代碼流程。
2.JProfiler
JProfiler很容易安裝,并且通過向導,你可以選擇應用服務器用來運行應 用程序。我不得不選擇使用JPofiler應用服務器的主目錄,以及向導生成的一個單獨的啟動腳本。然后運行服務器。在監聽會話的過程中,它會提供幾個選 項,它可以記錄內存的使用和CPU的使用率。在查看CPU使用率的同時,可以看到執行路徑。這讓我看到應用程序大部分時間都花在請求上。我們可以將 IntelliJ插件安裝到IDE上,那么運行JProfiler會更加便利。比如,可以直接幫我啟動Tomcat。
3.YourKit
YourKit是我在另一個項目中偶然發現的一款性能分析工具,它的安裝很簡 單。安裝時有一個選項,可以安裝一個插件到我的IDE。安裝后,運行應用程序,使用該插件,它會自動連接到YourKit。它有一個漂亮的用戶界面可以查 看到內存和CPU的監測,同時也可以看到請求的執行路徑。
4.JProbe
我剛開始創建JProbe時遇到點困難。安裝并不是直接完成,我需要對它進行配 置。它采用了類似JProfiler一樣的設置。它會在你的Tomcat目錄中生成啟動腳本,可以通過腳本啟動服務器并監聽會話。它的界面包含有按鈕和表 格,其中可以看到內存的使用,但無法在進程中找到執行路徑。
5.Spring Insight
聽到TC Server有Spring Insight監控界面,于是我興奮地嘗試了一下。安裝完成后,并設置成TC Server的開發者版,然后部署應用程序在TC Server上。我查看Insight界面,它可以很好的監視類和方法,并能看到完成這個方法用了多少時間。我還能看到輸入參數值,以及返回值。由于我的 應用程序是基于Spring的,Spring Insight能夠提供非常有用的數據。TC Server插件在IDE上的配置與Tomcat的配置類似。SpringSource工具套件就自帶Spring Insight。
結 論
看到這五款性能分析工具,我可以肯定地說,它們都非常不錯。如果你有基于Spring的應用程序,那么選擇Spring Insight顯然是最佳的。它一直是免費的,但你需要部署你的應用在TC Server上。
如果你想監聽本地和遠程的進程,我會選擇JProfiler或YourKit.這兩個也可以幫助Spring Insight來監測、找到性能瓶頸。
JProfiler和YourKit已經能滿足我的上述要求。 JProfiler、YourKit和Spring Insight都可以跟蹤應用程序的類和方法的流向。JProfiler和YourKit可以顯示內存使用情況。雖然Spring Insight不可以顯示內存使用情況,但它可以很好的顯示吞吐量的趨勢。這三款性能分析工具功能很清楚,不混亂,而且容易使用。最后,他們都有自己的 IDE插件。希望本文能幫助你做出正確的選擇。