JMeter是一個(gè)流行的用于負(fù)載測(cè)試的開(kāi)源工具,具有許多有用的功能元件,如線程組(threadgroup),定時(shí)器(timer),和HTTP取樣(sampler)元件。本文是對(duì)JMeter用戶手冊(cè)的補(bǔ)充,而且提供了關(guān)于使用Jmeter的一些模擬元件開(kāi)發(fā)質(zhì)量測(cè)試腳本的指導(dǎo)。
本文同時(shí)也討論了一項(xiàng)重要的內(nèi)容:在指定了精確的響應(yīng)時(shí)間要求后,如何來(lái)校驗(yàn)測(cè)試結(jié)果,筆者是在采用了置信區(qū)間分析這種嚴(yán)格的統(tǒng)計(jì)方式的情況下應(yīng)如何操作。請(qǐng)注重,我假定本文的讀者們了解關(guān)于Jmeter的基礎(chǔ)知識(shí),本文的例子基于Jmeter2。0。3版。
確定一個(gè)線程組的ramp-upperiod(Determine)
Jmeter腳本的第一個(gè)要素是線程組(ThreadGroup),因此首先讓我們往返顧一下。正如圖一所示,線程組需要設(shè)置以下參數(shù):
·線程數(shù)量。
·ramp-upperiod。
·運(yùn)行測(cè)試的次數(shù)。
·啟動(dòng)時(shí)間:立即或者預(yù)定的時(shí)間,假如是后者,線程組所包含的元素也要指定這個(gè)起止時(shí)間。
圖1:JMeter線程組(JMeterThreadGroup)
每個(gè)線程均獨(dú)立運(yùn)行測(cè)試計(jì)劃。因此,線程組常用來(lái)模擬并發(fā)用戶訪問(wèn)。假如客戶機(jī)沒(méi)有足夠的能力來(lái)模擬較重的負(fù)載,可以使用Jmeter的分布式測(cè)試功能來(lái)通過(guò)一個(gè)Jmeter控制臺(tái)來(lái)遠(yuǎn)程控制多個(gè)Jmeter引擎完成測(cè)試。
參數(shù)ramp-upperiod用于告知JMeter要在多長(zhǎng)時(shí)間內(nèi)建立全部的線程。默認(rèn)值是0。假如未指定ramp-upperiod,也是說(shuō)ramp-upperiod為零,JMeter將立即建立所有線程,假設(shè)ramp-upperiod設(shè)置成T秒,全部線程數(shù)設(shè)置成N個(gè),JMeter將每隔T/N秒建立一個(gè)線程。
線程組的大部分參數(shù)是不言自明的,只有ramp-upperiod有些難以理解,因?yàn)槿绾卧O(shè)置適當(dāng)?shù)闹挡⒉惠p易。首先,假如要使用大量線程的話,ramp-upperiod一般不要設(shè)置成零。因?yàn)榧偃缭O(shè)置成零,Jmeter將會(huì)在測(cè)試的開(kāi)始建立全部線程并立即發(fā)送訪問(wèn)請(qǐng)求,這樣一來(lái)很輕易使服務(wù)器飽和,更重要的是會(huì)隱性地增加了負(fù)載,這意味著服務(wù)器將可能過(guò)載,不是因?yàn)槠骄L問(wèn)率高而是因?yàn)樗芯程的第一次并發(fā)訪問(wèn)而引起的不正常的初始訪問(wèn)峰值,可以通過(guò)Jmeter的聚合報(bào)告監(jiān)聽(tīng)器看到這種現(xiàn)象。
這種異常不是我們需要的,因此,確定一個(gè)合理的ramp-upperiod的規(guī)則是讓初始點(diǎn)擊率接近平均點(diǎn)擊率。當(dāng)然,也許需要運(yùn)行一些測(cè)試來(lái)確定合理訪問(wèn)量。
基于同樣的原因,過(guò)大的ramp-upperiod也是不恰當(dāng)?shù)模驗(yàn)閷?huì)降低訪問(wèn)峰值的負(fù)載,換句話說(shuō),在一些線程還未啟動(dòng)時(shí),初期啟動(dòng)的部分線程可能已經(jīng)結(jié)束了。
那么,如何檢驗(yàn)ramp-upperiodI太小了或者太大了呢?首先,推測(cè)一下平均點(diǎn)擊率并用總線程除點(diǎn)擊率來(lái)計(jì)算初始的ramp-upperiod。例如,假設(shè)線程數(shù)為100,估計(jì)的點(diǎn)擊率為每秒10次,那么估計(jì)的理想ramp-upperiod是100/10=10秒。那么,應(yīng)怎樣來(lái)提出一個(gè)合理的估算點(diǎn)擊率呢?沒(méi)有什么好辦法,必須通過(guò)運(yùn)行一次測(cè)試腳本來(lái)獲得。
其次,在測(cè)試計(jì)劃(testplan)中增加一個(gè)聚合報(bào)告監(jiān)聽(tīng)器,如圖2所示,其中包含了所有獨(dú)立的訪問(wèn)請(qǐng)求(一個(gè)samplers)的平均點(diǎn)擊率。第一次取樣的點(diǎn)擊率(如http請(qǐng)求)與ramp-upperiod和線程數(shù)量密切相關(guān)。通過(guò)調(diào)整ramp-upperiod可以使首次取樣的奠基率接近平均取樣的點(diǎn)擊率。
圖2:JMeter聚合報(bào)告
第三,查驗(yàn)一下Jmeter日志(文件位置:JMeter_Home_Directory/bin)的后一個(gè)線程開(kāi)始時(shí)第一個(gè)線程是否真正結(jié)束了,二者的時(shí)間差是否正常。
總之,是否能確定一個(gè)適當(dāng)?shù)膔amp-uptime取決于以下兩條規(guī)則:
·第一個(gè)取樣器的點(diǎn)擊率(hitrate)是否接近其他取樣器的平均值,從而能否避免ramp-upperiod過(guò)小。
·在后一個(gè)線程啟動(dòng)時(shí),第一個(gè)線程是否在真正結(jié)束了,好二者的時(shí)間要盡可能的長(zhǎng),以避免ramp-upperiod過(guò)大。
有時(shí),這兩條規(guī)則的結(jié)論會(huì)互相沖突。這意味著無(wú)法找到同時(shí)滿足兩條規(guī)則的合適的ramp-upperiod。糟糕的測(cè)試計(jì)劃通常會(huì)導(dǎo)致這些問(wèn)題,這是因?yàn)樵谶@樣的測(cè)試計(jì)劃里,取樣器將不能充分地采集數(shù)據(jù),可能因?yàn)闇y(cè)試計(jì)劃執(zhí)行時(shí)間太短并且線程會(huì)很快的運(yùn)行結(jié)束。
用戶思考時(shí)間(Userthinktime),定時(shí)器,和代理服務(wù)器(PRoxyserver)
在負(fù)載測(cè)試中需要考慮的的一個(gè)重要要素是思考時(shí)間(thinktime),也是在兩次成功的訪問(wèn)請(qǐng)求之間的暫停時(shí)間。有多種情形揮發(fā)導(dǎo)致延遲的發(fā)生:用戶需要時(shí)間閱讀文字內(nèi)容,或者填表,或者查找正確的鏈接等。未認(rèn)真考慮思考時(shí)間經(jīng)常會(huì)導(dǎo)致測(cè)試結(jié)果的失真。例如,估計(jì)數(shù)值不恰當(dāng),也是被測(cè)系統(tǒng)可以支持的多用戶量(并發(fā)用戶)看起來(lái)似乎要少一些等。
當(dāng)我們進(jìn)入正在的負(fù)載測(cè)試后,如果發(fā)現(xiàn)事務(wù)控制器的時(shí)間比所有子組件的時(shí)間之和差距過(guò)大,那么說(shuō)明Jmeter本身的性能出問(wèn)題了。可以考慮通過(guò)如下三種方式進(jìn)行處理:
一、修改Jmeter.bat文件,調(diào)整JVM參數(shù),將heap和permsize值適當(dāng)?shù)脑O(shè)置大一點(diǎn)。
二、聯(lián)機(jī)負(fù)載,減少單臺(tái)機(jī)器上的負(fù)載線程數(shù)。
三、采用命令模式運(yùn)行測(cè)試。
Jmeter提供了一整套的計(jì)時(shí)器(timer)來(lái)模擬思考時(shí)間(thinktime),但是仍然存在一個(gè)問(wèn)題::如何確定適當(dāng)?shù)乃伎紩r(shí)間呢?幸運(yùn)的是,JMeter提供了一個(gè)不錯(cuò)的答案:使用JMeterHTTP代理服務(wù)器(ProxyServer)元件。
代理服務(wù)器會(huì)記錄在使用一個(gè)普通的瀏覽器(如Firefox或InternetEXPlorer)瀏覽一個(gè)web應(yīng)用時(shí)的操作。另外,JMeter在記錄操作的同時(shí)會(huì)建立一個(gè)測(cè)試計(jì)劃(testplan)。這個(gè)功能能提供以下便利:
不必手工建立HTTP訪問(wèn)請(qǐng)求,尤其是當(dāng)要設(shè)置一些令人乏味的參數(shù)時(shí)(然而,非英文的參數(shù)也許不能正常工作)。JMeter將會(huì)錄制包括隱含字段(hiddenfields)在內(nèi)的所有內(nèi)容。
在生成的測(cè)試計(jì)劃中,Jmeter會(huì)包含瀏覽器生成的所有的HTTP報(bào)頭,如User-Agent(e。g。,Mozilla/4。0),或AcceptLanguage(e。g。,zh-tw,en-us;q=0。7,zh-cn;q=0。3)等。
JMeter會(huì)根據(jù)設(shè)置在錄制操作的同時(shí)建立一些定時(shí)器,其延遲時(shí)間是完全根據(jù)真實(shí)的操作來(lái)設(shè)置的
現(xiàn)在讓我們來(lái)看一下如何配置Jmeter的錄制功能。在JMeter的控制臺(tái)上,在工作臺(tái)(WorkBench)元件上單擊右鍵,然后選擇”addtheHTTPProxyServer“。注重是在WorkBench上單擊右鍵而不是在TestPlan上,因?yàn)楝F(xiàn)在是要為記錄操作進(jìn)行配置而不是要運(yùn)行測(cè)試計(jì)劃。HTTPProxyServer的實(shí)現(xiàn)原理是通過(guò)配置瀏覽器的代理服務(wù)器而使所有的訪問(wèn)請(qǐng)求通過(guò)JMeter發(fā)送(,因而被Jmeter把訪問(wèn)過(guò)程錄制下來(lái))。
HTTP代理服務(wù)器(HTTPProxyServer)元件的一些參數(shù)必須被配置:
端口(port):代理服務(wù)器的監(jiān)聽(tīng)端口
目標(biāo)控制器(TargetController):是代理用于存儲(chǔ)生成的數(shù)據(jù)的控制器,默認(rèn)情況下,JMeter將會(huì)在當(dāng)前的測(cè)試計(jì)劃中找一個(gè)記錄用的控制器用于存儲(chǔ),此外也可以在下拉菜單中選擇任意控制起來(lái)存儲(chǔ),通常默認(rèn)值可以了。
分組(Grouping):確定在測(cè)試計(jì)劃中如何來(lái)為生成的元件分組。有多個(gè)選項(xiàng),一般可以選擇“只存儲(chǔ)每個(gè)組的第一個(gè)樣本”,否則,將會(huì)原樣錄制URLs,包括包含圖像和javascripts腳本的頁(yè)面。當(dāng)然也可以嘗試一下默認(rèn)值“不對(duì)樣本分組”("Donotgroupsamples"),來(lái)看一下JMeter建立的原版的測(cè)試計(jì)劃。
包含模式(PatternstoInclude)和排除模式(PatternstoExclude):幫助過(guò)濾一些不需要的訪問(wèn)請(qǐng)求。