JMeter是apache的jakarta上面的項(xiàng)目,用于軟件的壓力測試(Load Test),不但可以對HTTP,也可以對數(shù)據(jù)庫(通過JDBC)、FTP、Web Service、Java 對象等等進(jìn)行壓力測試。近,在我們的項(xiàng)目中使用到了它。我們的項(xiàng)目是基于BEA Weblogic的一個J2EE項(xiàng)目,在一個Domain中部署了3個J2EE應(yīng)用,這樣在客戶使用的過程中出現(xiàn)了WebLogic內(nèi)存垃圾回收的問題。于是我們配置了WebLogic集群,并將其中的某些應(yīng)用分開部署,并使用了JMeter進(jìn)行了性能測試。從而為應(yīng)用程序的性能診斷提供了必要的依據(jù)。
基本概念
JMeter的測試計(jì)劃(Test Plan)呈樹狀結(jié)構(gòu),樹里面有多種元素類型,樹狀結(jié)構(gòu)的元素之間有的是有繼承關(guān)系的(其原理有點(diǎn)類似log4j)。下面簡述一下元素類型:
1、ThreadGroup
顧名思義是線程組,測試必須有一個ThreadGroup元素作為基礎(chǔ)(否則沒有測試線程在跑了),這個元素可以配置跑多少個線程、每個線程循環(huán)多少次,所有線程數(shù)的總啟動時間(Ramp-up period)等等。
2、Controller
包括Logical Controller和Sampler,前者用來作一些邏輯上的控制,例如輪換、條件、循環(huán)等等。Sampler是真正“干活”的“取樣器”,例如“HTTP Request”,是拿來執(zhí)行一個HTTP請求的。
3、Listener
Listener對請求過程進(jìn)行監(jiān)聽,可以簡單理解為獲取結(jié)果的東東。例如Simple Data Writer,可以把結(jié)果寫到一個文本文件里(其實(shí)所有Listener都可以寫數(shù)據(jù)到文件里),還有View Results in Table,是把結(jié)果顯示在表格里。
4、 Timer
用來控制執(zhí)行流程中的時間延遲等功能。
5、 Assertion
斷言,加到Sampler里面可以對返回的結(jié)果進(jìn)行判斷,例如判斷HTTP返回結(jié)果里面是否含有某個字符串。如果斷言為真,JMeter會標(biāo)記請求為成功,否則標(biāo)記為失敗。
6、 Configuration Element
配置用的元素,很有用。由于測試計(jì)劃是樹狀和有繼承關(guān)系的,可以在高層次指定一個Configuration Element,低層次的相關(guān)Sampler如果沒有顯式地指定配置,繼承高層次的配置信息。(跟log4j很像吧?)
7、 Pre-Processor/Post-Processor Elements
用來在Sampler運(yùn)行前和運(yùn)行后作一些預(yù)處理和后處理工作的。例如動態(tài)修改請求的參數(shù)(預(yù)處理),從返回信息里面提取信息(后處理)等等。
要提醒一下的是jmeter根據(jù)當(dāng)前系統(tǒng)的locale顯示菜單的語言,為了方便想設(shè)置回英文的話,可以修改jmeter.properties文件,設(shè)置language=en
JMeter的使用
#啟動
大家可以到通過http://apache.linuxforum.net/dist/jakarta/jmeter/binaries/jakarta-jmeter-1.9.1.zip下載JMeter的release版本,然后將下載的.zip文件解壓縮到C:/JMeter(后面的文章中將使用%JMeter%來引用這個目錄)目錄下,F(xiàn)在,請使用%JMeter%/bin下面的jmeter.bat批處理文件來啟動JMeter的可視化界面,下面的工作都將在這個可視化界面界面上進(jìn)行操作。下面的圖片是JMeter的可視化界面的屏幕截圖。
圖一: JMeter打開時的屏幕截圖
# 建立測試計(jì)劃(Test Plan)
測試計(jì)劃描述了執(zhí)行測試過程中JMeter的執(zhí)行過程和步驟,一個完整的測試計(jì)劃包括一個或者多個線程組(Thread Groups)、邏輯控制(Logic Controller)、實(shí)例產(chǎn)生控制器(Sample Generating Controllers)、偵聽器(Listener)、定時器(Timer)、比較(Assertions)、配置元素(Config Elements)。打開JMeter時,它已經(jīng)建立一個默認(rèn)的測試計(jì)劃,一個JMeter應(yīng)用的實(shí)例只能建立或者打開一個測試計(jì)劃,F(xiàn)在我們開始填充一個測試計(jì)劃的內(nèi)容,這個測試計(jì)劃向一個jsp文件和一個servlet發(fā)出請求,我們需要JMeter模擬五個請求者(也是五個線程),每個請求者連續(xù)請求兩次,下面的章節(jié)介紹了詳細(xì)的操作步驟。
# 增加負(fù)載信息設(shè)置
這一步,我們將向測試計(jì)劃中增加相關(guān)負(fù)載設(shè)置,是Jmeter知道我們需要模擬五個請求者,每個請求者在測試過程中連續(xù)請求兩次。詳細(xì)步驟如下:
1. 選中可視化界面中左邊樹的Test Plan節(jié)點(diǎn),單擊右鍵,選擇Add'Thread Group,界面右邊將會出現(xiàn)他的設(shè)置信息框。
2. Thread Group有三個和負(fù)載信息相關(guān)的參數(shù):
Number of Threads: 設(shè)置發(fā)送請求的用戶數(shù)目
Ramp-up period: 每個請求發(fā)生的總時間間隔,單位是秒。比如你的請求數(shù)目是5,而這個參數(shù)是10,那么每個請求之間的間隔是10/5,也是2秒
Loop Count: 請求發(fā)生的重復(fù)次數(shù),如果選擇后面的forever(默認(rèn)),那么 請求將一直繼續(xù),如果不選擇forever,而在輸入框中輸入數(shù)字,那么請求將重復(fù) 指定的次數(shù),如果輸入0,那么請求將執(zhí)行一次。