如何使用英文界面的JMeter
Jmeter啟動時會自動判斷操作系統(tǒng)的locale 并選擇合適的語言啟動,所以,我們啟動jmeter后,其會出現(xiàn)一個倍感親切的中文界面。但由于jmeter本身的漢化工作做得不好,你會看到有未被漢化的選項及元件的參數(shù)。而且部分翻譯并不準(zhǔn)確,因此對于英文比較好的牛人來說更喜歡純正的英文界面。
強(qiáng)制以英文方式啟動jmeter的方法如下:
在windows環(huán)境下,打開jmeter解壓目錄,bin目錄下的jmeter.bat文件,也就是jmeter程序的啟動文件,選擇記事本方式打開。做以下修改:
................. set HEAP=-Xms512m -Xmx512m set NEW=-XX:NewSize=128m -XX:MaxNewSize=128m set SURVIVOR=-XX:SurvivorRatio=8 -XX:TargetSurvivorRatio=50% set TENURING=-XX:MaxTenuringThreshold=2 set RMIGC=-Dsun.rmi.dgc.client.gcInterval=600000 -Dsun.rmi.dgc.server.gcInterval=600000 set PERM=-XX:PermSize=64m -XX:MaxPermSize=64m set LOCALE=-Duser.language=en -Duser.region=rem set DEBUG=-verbose:gc -XX:+PrintTenuringDistribution ......... rem Server mode rem Collect the settings defined above set ARGS=%DUMP% %HEAP% %NEW% %SURVIVOR% %TENURING% %RMIGC% %PERM% %DDRAW% %LOCALE% .............
暈死,當(dāng)我上面介紹了那么多后,在最新的2.8版本,我無意中發(fā)現(xiàn)了這個功能。
如何使用鏡像服務(wù)器
在調(diào)試和修改測試計劃的過程中,通常會為采樣器增加一些額外的設(shè)置,例何設(shè)置額外的HTTP頭、cookie管理器或認(rèn)證管理器等,但當(dāng)設(shè)置了這些內(nèi)容后,sampler發(fā)出的請求是否就與預(yù)期的完全一支呢?
當(dāng)然用戶可以通過添加監(jiān)聽器來看查采樣器發(fā)出的HTTP請求,但如果調(diào)試過程中并不想真正地把請求發(fā)送給被測應(yīng)用,如何解決這個問題呢?
Jmeter 提供了一個名叫HTTP Mirror Server的組件,HTTP Mirror Server可以啟動一個鏡像的服務(wù)器,該服務(wù)器把所有接收到的請求原封不動地返回,這樣就可以看到發(fā)出請求的具體內(nèi)容了。
添加HTTP Mirror Server的方式:
右鍵點擊“工作臺”--->非測試元件--->HTTP Mirror Server
如果有必要的話需要修改端口號,點擊“啟動”按鈕來啟動Server 。
接下來修改采樣器,使其將HTTP請求 發(fā)送到localhost:8081(也就是Mirror Server啟動的位置)
然后,運行測試計劃,則可以從監(jiān)聽器“查看結(jié)果樹”中看到響應(yīng)數(shù)據(jù)。
JMeter分布式測試
Jmeter 是java 應(yīng)用,對于CPU和內(nèi)存的消耗比較大,因此,當(dāng)需要模擬數(shù)以千計的并發(fā)用戶時,使用單臺機(jī)器模擬所有的并發(fā)用戶就有些力不從心,甚至?xí)餔AVA內(nèi)存溢出錯誤。為了讓jmeter工具提供更大的負(fù)載能力,jmeter短小精悍一有了使用多臺機(jī)器同時產(chǎn)生負(fù)載的機(jī)制。
那么,是如何實現(xiàn)多臺負(fù)載機(jī)同時運行的呢?當(dāng)然不會多個人坐在多臺負(fù)載機(jī)面前,一喊開始,大家同時啟動jmeter。這種方式很笨,也很難達(dá)到真正的同步。其實,我們通過單個jmeter 客戶端就可以控制多個遠(yuǎn)程的jmeter服務(wù)器,使它們同步的對服務(wù)器進(jìn)行壓力測試。
通過遠(yuǎn)程運行jmeter,測試人員可以跨越多臺低端計算機(jī)復(fù)制測試,這樣就可以模擬一個比較大的服務(wù)器壓力,一個jmeter客戶端實例,理論上可以控制任意多的遠(yuǎn)程jmeter實例,并通過他們收集測試數(shù)據(jù)。這樣一樣,就有了如下特性:
* 保存測試采樣數(shù)據(jù)到本地機(jī)器
* 通過單臺機(jī)器管理多個jmeter執(zhí)行引擎。
* 沒有必要將測試計劃復(fù)制到每一臺機(jī)器,jmeter GUI客戶端會將它發(fā)往每一臺jmeter服務(wù)器。
* 每一臺jmeter遠(yuǎn)程服務(wù)器都執(zhí)行相同的測試計劃,jmeter不會在執(zhí)行期間做負(fù)載均衡,每一臺服務(wù)器都會完整地運行測試計劃。
在1.4G Hz~3GHz 的CPU 、1GB 內(nèi)存的 JMeter 客戶端上,可以處理線程 100~300。但是Web Service 例外。XML處理是 CPU 運算密集的,會迅速消耗掉所有的CPU 。一般來說,以XML技術(shù)為核心的應(yīng)用系統(tǒng),其性能將是普通Web 應(yīng)用的 10%~25% 。另外,如果所有負(fù)載由一臺機(jī)器產(chǎn)生,網(wǎng)卡和交換機(jī)端口都可能產(chǎn)生瓶頸,所以一個JMeter 客戶端線程數(shù)不應(yīng)超過 10 0 。
采用JMeter 遠(yuǎn)程模式并不會比獨立運行相同數(shù)目的非GUI 測試更耗費資源。但是,如果使用大量的JMeter 遠(yuǎn)程服務(wù)器,可能會導(dǎo)致客戶端過載,或者網(wǎng)絡(luò)連接發(fā)生擁塞。
使用多臺機(jī)器產(chǎn)生負(fù)載的操作步驟如下:
(1)在所有期望運行jmeter作為 負(fù)載生成器的機(jī)器上安裝jmeter, 并確定其中一臺機(jī)器作為 controller ,其他的的機(jī)器作為agent 。然后運行所有 agent 機(jī)器上的jmeter-server 文件(假定使用兩臺機(jī)器192.168.0.100 和192.168.0.101 作為agent)
(2)在controller機(jī)器的jmeter的bin目錄下,找到j(luò)meter.properties 文件,編輯該文件:
查找: remote_hosts=127.0.0.1 修改為: remote_hosts=192.168.0.100:1099,192.168.0.101:1099
這里要特別注意端口后,有些資料說明端口1644為jmeter的controller 和agent 之間進(jìn)行通信的默認(rèn)RMI端口號,但是在測試時發(fā)現(xiàn),設(shè)置為1644運行不成功,改成1099后運行通過。另外還要留意agent的機(jī)子是否開啟了防火墻等。
(3)啟動controller 機(jī)子上的jmeter應(yīng)用,選擇菜單“運行”--->“遠(yuǎn)程啟動”,來分別啟動agent ,也可以直接選擇“遠(yuǎn)程全部啟動”來將所有的agent啟動。
啟動Debug 日志記錄
大多數(shù)測試元件都支持Debug 日志記錄。如果通過 GUI 運行測試計劃,那么在選中測試元件后,可以通過“幫助”菜單enable debug或者disable debug。在“幫助”菜單 中有一個選項“What’s this node? ”,
通過它可以查看GUI 和測試元件的類名,如圖 11 -7 所示。通過它們,測試人員可以決定修改哪一項JMeter 屬性,以便修改日志級別。
例如:我們可以點擊一個HTTP請求,選擇菜單欄“幫助”--->what's this node ?
在jmeter的bin\目錄下,找到j(luò)meter.properties 文件,關(guān)于日志級別的屬性如下:
#Logging levels for the logging categories in JMeter. Correct values are FATAL_ERROR, ERROR, WARN, INFO, and DEBUG # To set the log level for a package or individual class, use: # log_level.[package_name].[classname]=[PRIORITY_LEVEL] # But omit "org.apache" from the package name. The classname is optional. Further examples below. log_level.jmeter=INFO log_level.jmeter.junit=DEBUG #log_level.jmeter.control=DEBUG #log_level.jmeter.testbeans=DEBUG #log_level.jmeter.engine=DEBUG #log_level.jmeter.threads=DEBUG #log_level.jmeter.gui=WARN #log_level.jmeter.testelement=DEBUG #log_level.jmeter.util=WARN #log_level.jmeter.util.classfinder=WARN #log_level.jmeter.test=DEBUG #log_level.jmeter.protocol.http=DEBUG # For CookieManager, AuthManager etc: #log_level.jmeter.protocol.http.control=DEBUG #log_level.jmeter.protocol.ftp=WARN #log_level.jmeter.protocol.jdbc=DEBUG #log_level.jmeter.protocol.java=WARN #log_level.jmeter.testelements.property=DEBUG log_level.jorphan=INFO
搜索功能
這是在使用一個變量或含有一定的URL或參數(shù)測試計劃樹和元素有時很難找到,F(xiàn)在一個新的特點是從2.6開始,你可以訪問它的菜單搜索。它提供了搜索與下列選項:
* 使搜索區(qū)分大小寫區(qū)分大小寫:
* 正則表達(dá)式是一個正則表達(dá)式搜索文本,如果有的話將被搜索的正則表達(dá)式樹的組件,例如“\ BTEST \ b”將匹配任何組件,包含測試組件的搜索元素
線程之間傳遞變量
JMeter 變量作用域局限于所屬線程。這樣設(shè)計是經(jīng)過深思熟慮的,目的是讓測試線程能夠獨立運轉(zhuǎn)。有時候用戶可能需要在不同線程間(可能屬于同一個線程組,也可能不屬于同一個線程組)傳遞變量。
其中一種方法就是使用屬性。屬性為所有 JMeter 線程所共享,因此當(dāng)某個線程設(shè)置一個屬性后,其他線程就可以讀取更新后的值。
如果存在大量數(shù)據(jù)需要在線程間傳遞,那么可以考慮使用文件。例如,測試人員可以在一個線程中使用監(jiān)聽器,保存響應(yīng)到文件(Save Responses to a file )或者 BeanShell PostProcessor 。而在另外一個線程中使用HTTP 采樣器的“file: ”協(xié)議來讀取文件,接著使用一個后置處理器或者BeanShell 測試元件提取信息。
如果在測試啟動前測試人員就能獲得測試數(shù)據(jù),那么最好將數(shù)據(jù)保存到文件中,使用CSV Dataset讀取。
----------------------------------------
這最后一個技巧,操作較為麻煩,暫時不給詳細(xì)的例子。算是提供個思路吧!知道有這當(dāng)子事兒就行了。日后有機(jī)會再實踐^_^