原創(chuàng)|其它|編輯:郝浩|2012-10-17 15:07:12.000|閱讀 276 次
概述:在給客戶的應(yīng)用程序維護(hù)的過(guò)程中,我注意到在高負(fù)載下的一些性能問(wèn)題。理論上,增加對(duì)應(yīng)用程序的負(fù)載會(huì)使性能等比率的下降。
# 界面/圖表報(bào)表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
在給客戶進(jìn)行應(yīng)用程序維護(hù)的過(guò)程中,我注意到一些關(guān)于高負(fù)載條件下的性能問(wèn)題。理論上,增加對(duì)應(yīng)用程序的負(fù)載會(huì)使性能有所下降,但是我認(rèn)為性能下降的比率遠(yuǎn)遠(yuǎn)高于負(fù)載的增加,同時(shí)我也發(fā)現(xiàn),性能可以通過(guò)改變應(yīng)用程序的邏輯來(lái)提升。為了更詳細(xì)地了解這一點(diǎn),我們需要做一些性能分析,這時(shí),我們自然就要用到一些性能分析工具。Java有許多的性能分析工具,可以幫助我們弄清楚這個(gè)問(wèn)題,但是我們應(yīng)該使用哪一款工具呢?
為了做出正確的選擇,我列出性能分析應(yīng)滿足一些最低要求:
我配置了一個(gè)使用RESTful接口的Spring應(yīng)用程序,使用MongoDB作為數(shù)據(jù)存儲(chǔ),還使用Solr搜索,并在Tomcat服務(wù)器上部署。
1.VisualVM
VisualVM是一個(gè)資源分析工具,一直從JDK 6更新到7,它默認(rèn)內(nèi)存和CPU的監(jiān)視,它可以告訴你哪個(gè)類和方法消耗資源,但它不會(huì)顯示代碼流程。
下載地址://java.net/projects/visualvm/downloads/download/release134/visualvm_134.zip
JProfiler很容易安裝,并且通過(guò)向?qū)В憧梢赃x擇應(yīng)用服務(wù)器用來(lái)運(yùn)行應(yīng)用程序。我不得不選擇使用JPofiler應(yīng)用服務(wù)器的主目錄,以及向?qū)傻囊粋€(gè)單獨(dú)的啟動(dòng)腳本。然后運(yùn)行服務(wù)器。在監(jiān)聽會(huì)話的過(guò)程中,它會(huì)提供幾個(gè)選項(xiàng),它可以記錄內(nèi)存的使用和CPU的使用率。在查看CPU使用率的同時(shí),可以看到執(zhí)行路徑。這讓我看到應(yīng)用程序大部分時(shí)間都花在請(qǐng)求上。我們可以將IntelliJ插件安裝到IDE上,那么運(yùn)行JProfiler會(huì)更加便利。比如,可以直接幫我啟動(dòng)Tomcat。
下載地址://fc6vip.cn/zh-CN/product/743/download.aspx
3.YourKit
YourKit是我在另一個(gè)項(xiàng)目中偶然發(fā)現(xiàn)的一款性能分析工具,它的安裝很簡(jiǎn)單。安裝時(shí)有一個(gè)選項(xiàng),可以安裝一個(gè)插件到我的IDE。安裝后,運(yùn)行應(yīng)用程序,使用該插件,它會(huì)自動(dòng)連接到Y(jié)ourKit。它有一個(gè)漂亮的用戶界面可以查看到內(nèi)存和CPU的監(jiān)測(cè),同時(shí)也可以看到請(qǐng)求的執(zhí)行路徑。
下載地址://www.yourkit.com/download/yjp-11.0.9.exe
4.JProbe
我剛開始創(chuàng)建JProbe時(shí)遇到點(diǎn)困難。安裝并不是直接完成,我需要對(duì)它進(jìn)行配置。它采用了類似JProfiler一樣的設(shè)置。它會(huì)在你的Tomcat目錄中生成啟動(dòng)腳本,可以通過(guò)腳本啟動(dòng)服務(wù)器并監(jiān)聽會(huì)話。它的界面包含有按鈕和表格,其中可以看到內(nèi)存的使用,但無(wú)法在進(jìn)程中找到執(zhí)行路徑。
下載地址://www.quest.com/jprobe/
5.Spring Insight
聽到TC Server有Spring Insight監(jiān)控界面,于是我興奮地嘗試了一下。安裝完成后,并設(shè)置成TC Server的開發(fā)者版,然后部署應(yīng)用程序在TC Server上。我查看Insight界面,它可以很好的監(jiān)視類和方法,并能看到完成這個(gè)方法用了多少時(shí)間。我還能看到輸入?yún)?shù)值,以及返回值。由于我的應(yīng)用程序是基于Spring的,Spring Insight能夠提供非常有用的數(shù)據(jù)。TC Server插件在IDE上的配置與Tomcat的配置類似。SpringSource工具套件就自帶Spring Insight。
下載地址://www.springsource.org/insight/download-choose
看到這五款性能分析工具,我可以肯定地說(shuō),它們都非常不錯(cuò)。如果你有基于Spring的應(yīng)用程序,那么選擇Spring Insight顯然是最佳的。它一直是免費(fèi)的,但你需要部署你的應(yīng)用在TC Server上。
如果你想監(jiān)聽本地和遠(yuǎn)程的進(jìn)程,我會(huì)選擇JProfiler或YourKit。這兩個(gè)也可以幫助Spring Insight來(lái)監(jiān)測(cè)、找到性能瓶頸。
JProfiler和YourKit已經(jīng)能滿足我的上述要求。JProfiler、YourKit和Spring Insight都可以跟蹤應(yīng)用程序的類和方法的流向。JProfiler和YourKit可以顯示內(nèi)存使用情況。雖然Spring Insight不可以顯示內(nèi)存使用情況,但它可以很好的顯示吞吐量的趨勢(shì)。這三款性能分析工具功能很清楚,不混亂,而且容易使用。最后,他們都有自己的 IDE插件。希望本文能幫助你做出正確的選擇。
本站文章除注明轉(zhuǎn)載外,均為本站原創(chuàng)或翻譯。歡迎任何形式的轉(zhuǎn)載,但請(qǐng)務(wù)必注明出處、不得修改原文相關(guān)鏈接,如果存在內(nèi)容上的異議請(qǐng)郵件反饋至chenjj@fc6vip.cn
文章轉(zhuǎn)載自:Aaron chinaitlab