JMeter是apache的jakarta上面的項(xiàng)目,用于軟件的 壓力測(cè)試(Load Test),不但可以對(duì)HTTP,也可以對(duì)數(shù)據(jù)庫(kù)(通過(guò)JDBC)、FTP、Web Service、Java 對(duì)象等等進(jìn)行壓力測(cè)試。最近,在我們的項(xiàng)目中使用到了它。我們的項(xiàng)目是基于BEA Weblogic的一個(gè)J2EE項(xiàng)目,在一個(gè)Domain中部署了3個(gè)J2EE應(yīng)用,這樣在客戶使用的過(guò)程中出現(xiàn)了WebLogic內(nèi)存垃圾回收的問題。于是我們配置了WebLogic集群,并將其中的某些應(yīng)用分開部署,并使用了JMeter進(jìn)行了性能測(cè)試。從而為應(yīng)用程序的性能診斷提供了必要的依據(jù)。
基本概念
JMeter的測(cè)試計(jì)劃(Test Plan)呈樹狀結(jié)構(gòu),樹里面有多種元素類型,樹狀結(jié)構(gòu)的元素之間有的是有繼承關(guān)系的(其原理有點(diǎn)類似log4j)。下面簡(jiǎn)述一下元素類型:
1、ThreadGroup
顧名思義就是線程組,測(cè)試必須有一個(gè)ThreadGroup元素作為基礎(chǔ)(否則就沒有測(cè)試線程在跑了),這個(gè)元素可以配置跑多少個(gè)線程、每個(gè)線程循環(huán)多少次,所有線程數(shù)的總啟動(dòng)時(shí)間(Ramp-up period)等等。
2、Controller
包括Logical Controller和Sampler,前者用來(lái)作一些邏輯上的控制,例如輪換、條件、循環(huán)等等。Sampler就是真正“干活”的“取樣器”,例如“HTTP Request”,就是拿來(lái)執(zhí)行一個(gè)HTTP請(qǐng)求的。
3、Listener
Listener對(duì)請(qǐng)求過(guò)程進(jìn)行監(jiān)聽,可以簡(jiǎn)單理解為獲取結(jié)果的東東。例如Simple Data
Writer,可以把結(jié)果寫到一個(gè)文本文件里(其實(shí)所有Listener都可以寫數(shù)據(jù)到文件里),還有View Results in
Table,就是把結(jié)果顯示在表格里。
4、 Timer
用來(lái)控制執(zhí)行流程中的時(shí)間延遲等功能。
5、 Assertion
斷言,加到Sampler里面可以對(duì)返回的結(jié)果進(jìn)行判斷,例如判斷HTTP返回結(jié)果里面是否含有某個(gè)字符串。如果斷言為真,JMeter會(huì)標(biāo)記請(qǐng)求為成功,否則標(biāo)記為失敗。
6、 Configuration Element
配置用的元素,很有用。由于測(cè)試計(jì)劃是樹狀和有繼承關(guān)系的,可以在高層次指定一個(gè)Configuration Element,低層次的相關(guān)Sampler如果沒有顯式地指定配置,就繼承高層次的配置信息。(跟log4j很像吧?)
7、 Pre-Processor/Post-Processor Elements
用來(lái)在Sampler運(yùn)行前和運(yùn)行后作一些預(yù)處理和后處理工作的。例如動(dòng)態(tài)修改請(qǐng)求的參數(shù)(預(yù)處理),從返回信息里面提取信息(后處理)等等。
要提醒一下的是jmeter根據(jù)當(dāng)前系統(tǒng)的locale顯示菜單的語(yǔ)言,為了方便想設(shè)置回英文的話,可以修改jmeter.properties文件,設(shè)置language=en
JMeter的使用
#啟動(dòng)
大家可以到通過(guò)http://apache.linuxforum.net/dist/jakarta/jmeter/binaries/jakarta-jmeter-1.9.1.zip下 載JMeter的release版本,然后將下載的.zip文件解壓縮到C:/JMeter(后面的文章中將使用%JMeter%來(lái)引用這個(gè)目錄)目錄 下。現(xiàn)在,請(qǐng)使用%JMeter%/bin下面的jmeter.bat批處理文件來(lái)啟動(dòng)JMeter的可視化界面,下面的工作都將在這個(gè)可視化界面界面上 進(jìn)行操作。下面的圖片是JMeter的可視化界面的屏幕截圖。
圖一: JMeter打開時(shí)的屏幕截圖?
# 建立測(cè)試計(jì)劃(Test Plan)
測(cè)試計(jì)劃描述了執(zhí)行測(cè)試過(guò)程中JMeter的執(zhí)行過(guò)程和步驟,一個(gè)完整的測(cè)試計(jì)劃包括一個(gè)或者多個(gè)線程組(Thread Groups)、邏輯控制(Logic Controller)、實(shí)例產(chǎn)生控制器(Sample Generating Controllers)、偵聽器(Listener)、定時(shí)器(Timer)、比較(Assertions)、配置元素(Config Elements)。打開JMeter時(shí),它已經(jīng)建立一個(gè)默認(rèn)的測(cè)試計(jì)劃,一個(gè)JMeter應(yīng)用的實(shí)例只能建立或者打開一個(gè)測(cè)試計(jì)劃?,F(xiàn)在我們開始填充一 個(gè)測(cè)試計(jì)劃的內(nèi)容,這個(gè)測(cè)試計(jì)劃向一個(gè)jsp文件和一個(gè)servlet發(fā)出請(qǐng)求,我們需要JMeter模擬五個(gè)請(qǐng)求者(也就是五個(gè)線程),每個(gè)請(qǐng)求者連續(xù) 請(qǐng)求兩次,下面的章節(jié)介紹了詳細(xì)的操作步驟。
# 增加負(fù)載信息設(shè)置
這一步,我們將向測(cè)試計(jì)劃中增加相關(guān)負(fù)載設(shè)置,是Jmeter知道我們需要模擬五個(gè)請(qǐng)求者,每個(gè)請(qǐng)求者在測(cè)試過(guò)程中連續(xù)請(qǐng)求兩次。詳細(xì)步驟如下:
1. 選中可視化界面中左邊樹的Test Plan節(jié)點(diǎn),單擊右鍵,選擇Add'Thread Group,界面右邊將會(huì)出現(xiàn)他的設(shè)置信息框。
2. Thread Group有三個(gè)和負(fù)載信息相關(guān)的參數(shù):
Number of Threads: 設(shè)置發(fā)送請(qǐng)求的用戶數(shù)目
Ramp-up period: 每個(gè)請(qǐng)求發(fā)生的總時(shí)間間隔,單位是秒。比如你的請(qǐng)求數(shù)目是5,而這個(gè)參數(shù)是10,那么每個(gè)請(qǐng)求之間的間隔就是10/5,也就是2秒
Loop Count: 請(qǐng)求發(fā)生的重復(fù)次數(shù),如果選擇后面的forever(默認(rèn)),那么 請(qǐng)求將一直繼續(xù),如果不選擇forever,而在輸入框中輸入數(shù)字,那么請(qǐng)求將重復(fù) 指定的次數(shù),如果輸入0,那么請(qǐng)求將執(zhí)行一次。
根據(jù)我們演示例子的設(shè)計(jì),我們應(yīng)該將Number of Threads設(shè)置為5,Ramp-up period設(shè)置為0(也就是同時(shí)并發(fā)請(qǐng)求),不選中forever,在Loop Count后面的輸入框中輸入2,設(shè)置后的屏幕截圖如下:
圖二:設(shè)置好參數(shù)的Thread Group。
# 增加默認(rèn)Http屬性(可選)
實(shí)際的測(cè)試工作往往是針對(duì)同一個(gè)服務(wù)器上Web應(yīng)用展開的,所以Jmeter提供了這樣一種設(shè)置, 在默認(rèn)Http屬性設(shè)置需要被測(cè)試服務(wù)器的相關(guān)屬性,以后的http請(qǐng)求設(shè)置中就可以忽略這些相同參數(shù)的設(shè)置,減少設(shè)置參數(shù)錄入的時(shí)間。我們這里將采用這種屬性。你可以通過(guò)下面的步驟來(lái)設(shè)置默認(rèn)http屬性:
1. 選中可視化界面中左邊樹的Test Plan節(jié)點(diǎn),單擊右鍵,選擇Add'config element'http request defaults,界面右邊將會(huì)出現(xiàn)他的設(shè)置信息框。
2. 默認(rèn)http屬性的主要參數(shù)說(shuō)明如下:
protocal:發(fā)送測(cè)試請(qǐng)求時(shí)使用的協(xié)議
server name or ip:被測(cè)試服務(wù)器的ip地址或者名字
path: 默認(rèn)的起始位置。比如將path設(shè)置為/jmeter,那么所有的http請(qǐng)求的url中都將增加/jmeter路徑。
port number: 服務(wù)器提供服務(wù)的端口號(hào)
我們的測(cè)試計(jì)劃將針對(duì)本機(jī)的Web服務(wù)器上的Web應(yīng)用進(jìn)行測(cè)試,所以protocal應(yīng)該是http,ip使用localhost,因?yàn)檫@個(gè)web應(yīng) 用發(fā)布的context路徑是/jmeter,所以這里的path設(shè)置為/jmeter,因?yàn)槭褂肨omcat服務(wù)器,所以port number是8080。# ?增加Http請(qǐng)求
現(xiàn)在我們需要增加http請(qǐng)求了,他也是我們測(cè)試的內(nèi)容主體部分。你可以通過(guò)下面的步驟來(lái)增加性的http請(qǐng)求:
1. 選中可視化界面中左邊樹的Thread Group節(jié)點(diǎn),單擊右鍵,選擇Add'sampler'http request,界面右邊將會(huì)出現(xiàn)他的設(shè)置信息框。
2. 他的參數(shù)和2.5中介紹的http屬性差不多,增加的屬性中有發(fā)送http時(shí)方法的選擇,你可以選擇為get或者post。
我們現(xiàn)在增加兩個(gè)http 請(qǐng)求,因?yàn)槲覀冊(cè)O(shè)置了默認(rèn)的http屬性,所以和默認(rèn)http屬性中相同的屬性不再重復(fù)設(shè)置。設(shè)置后的屏幕截圖如下:
圖三:設(shè)置好的jsp測(cè)試請(qǐng)求
圖四:設(shè)置好的Servlet測(cè)試請(qǐng)求(帶參數(shù))?
# 增加Listener
增加listener是為了記錄測(cè)試信息并且可以使用Jmeter提供的可視化界面查看測(cè)試結(jié)果,里面有好幾種結(jié)果分析方式可供選擇,你可以根據(jù)自己習(xí) 慣的分析方式選擇不同的結(jié)果顯示方式,我們這里使用表格的形式來(lái)查看和分析測(cè)試結(jié)果。你可以通過(guò)下面的步驟來(lái)增加listener:
1. 選中可視化界面中左邊樹的Test Plan節(jié)點(diǎn),單擊右鍵,選擇Add'listener'view result in table,界面右邊將會(huì)出現(xiàn)他的設(shè)置信息和結(jié)果顯示框。
2. 你可以設(shè)置界面上面的filename屬性設(shè)置將測(cè)試結(jié)果保存到某個(gè)文件中界面下面將使用表格顯示測(cè)試結(jié)果,表格的第一列sampleno顯示請(qǐng)求執(zhí)行的 順序和編號(hào),url顯示 請(qǐng)求發(fā)送的目標(biāo),sample-ms列顯示這個(gè)請(qǐng)求完成耗費(fèi)的時(shí)間,最后的success列顯示改請(qǐng)求是否成功執(zhí)行。界面的最 下面你還可以看到一些統(tǒng)計(jì)信息,最關(guān)心的應(yīng)該是Average吧,也就是相應(yīng)的平均時(shí)間。?
# 開始執(zhí)行測(cè)試計(jì)劃
現(xiàn)在你可以通過(guò)單擊菜單欄run -> Start開始執(zhí)行測(cè)試計(jì)劃了。下面是該測(cè)試計(jì)劃的結(jié)果圖:
圖五:結(jié)果顯示
JMeter用于進(jìn)行供能或者性能測(cè)試,通過(guò)使用JMeter提供的供能,我們可以可視化的制定測(cè)試計(jì)劃:包括規(guī)定使用什么樣的負(fù)載、測(cè)試什么內(nèi)容、傳入的參數(shù),同時(shí),他提供了好多種圖形化的測(cè)試結(jié)果顯示方式,使我們能夠簡(jiǎn)單的開始測(cè)試工作和分析測(cè)試結(jié)果。