qileilove

          blog已經(jīng)轉(zhuǎn)移至github,大家請(qǐng)?jiān)L問 http://qaseven.github.io/

          性能測(cè)試工具JMeter的使用技巧

          在這此對(duì)新版本jmeter的學(xué)習(xí)+溫習(xí)的過程,發(fā)現(xiàn)了一些以前不知道的功能,所以,整理出來與大分享。本文內(nèi)容如下。

            1、如何使用英文界面的jmeter
            2、如何使用鏡像服務(wù)器
            3、Jmeter分布式測(cè)試
            4、啟動(dòng)Debug 日志記錄
            5、搜索功能
            6、線程之間傳遞變量

            如何使用英文界面的JMeter

            Jmeter啟動(dòng)時(shí)會(huì)自動(dòng)判斷操作系統(tǒng)的locale 并選擇合適的語言啟動(dòng),所以,我們啟動(dòng)jmeter后,其會(huì)出現(xiàn)一個(gè)倍感親切的中文界面。但由于jmeter本身的漢化工作做得不好,你會(huì)看到有未被漢化的選項(xiàng)及元件的參數(shù)。而且部分翻譯并不準(zhǔn)確,因此對(duì)于英文比較好的牛人來說更喜歡純正的英文界面。

            強(qiáng)制以英文方式啟動(dòng)jmeter的方法如下:

            在windows環(huán)境下,打開jmeter解壓目錄,bin目錄下的jmeter.bat文件,也就是jmeter程序的啟動(dòng)文件,選擇記事本方式打開。做以下修改:

          .................
          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)了這個(gè)功能。

            如何使用鏡像服務(wù)器

            在調(diào)試和修改測(cè)試計(jì)劃的過程中,通常會(huì)為采樣器增加一些額外的設(shè)置,例何設(shè)置額外的HTTP頭、cookie管理器或認(rèn)證管理器等,但當(dāng)設(shè)置了這些內(nèi)容后,sampler發(fā)出的請(qǐng)求是否就與預(yù)期的完全一支呢?

            當(dāng)然用戶可以通過添加監(jiān)聽器來看查采樣器發(fā)出的HTTP請(qǐng)求,但如果調(diào)試過程中并不想真正地把請(qǐng)求發(fā)送給被測(cè)應(yīng)用,如何解決這個(gè)問題呢?

            Jmeter 提供了一個(gè)名叫HTTP Mirror Server的組件,HTTP Mirror Server可以啟動(dòng)一個(gè)鏡像的服務(wù)器,該服務(wù)器把所有接收到的請(qǐng)求原封不動(dòng)地返回,這樣就可以看到發(fā)出請(qǐng)求的具體內(nèi)容了。

            添加HTTP Mirror Server的方式:

            右鍵點(diǎn)擊“工作臺(tái)”--->非測(cè)試元件--->HTTP Mirror Server

            如果有必要的話需要修改端口號(hào),點(diǎn)擊“啟動(dòng)”按鈕來啟動(dòng)Server。

           采用JMeter 遠(yuǎn)程模式并不會(huì)比獨(dú)立運(yùn)行相同數(shù)目的非GUI 測(cè)試更耗費(fèi)資源。但是,如果使用大量的JMeter 遠(yuǎn)程服務(wù)器,可能會(huì)導(dǎo)致客戶端過載,或者網(wǎng)絡(luò)連接發(fā)生擁塞。

            使用多臺(tái)機(jī)器產(chǎn)生負(fù)載的操作步驟如下:

            (1)在所有期望運(yùn)行jmeter作為 負(fù)載生成器的機(jī)器上安裝jmeter, 并確定其中一臺(tái)機(jī)器作為 controller ,其他的的機(jī)器作為agent 。然后運(yùn)行所有 agent 機(jī)器上的jmeter-server 文件(假定使用兩臺(tái)機(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端口號(hào),但是在測(cè)試時(shí)發(fā)現(xiàn),設(shè)置為1644運(yùn)行不成功,改成1099后運(yùn)行通過。另外還要留意agent的機(jī)子是否開啟了防火墻等。

            (3)啟動(dòng)controller 機(jī)子上的jmeter應(yīng)用,選擇菜單“運(yùn)行”--->“遠(yuǎn)程啟動(dòng)”,來分別啟動(dòng)agent ,也可以直接選擇“遠(yuǎn)程全部啟動(dòng)”來將所有的agent啟動(dòng)。

            啟動(dòng)Debug 日志記錄

            大多數(shù)測(cè)試元件都支持Debug 日志記錄。如果通過 GUI 運(yùn)行測(cè)試計(jì)劃,那么在選中測(cè)試元件后,可以通過“幫助”菜單enable debug或者disable debug。在“幫助”菜單 中有一個(gè)選項(xiàng)“What’s this node? ”,

            通過它可以查看GUI 和測(cè)試元件的類名,如圖 11 -7 所示。通過它們,測(cè)試人員可以決定修改哪一項(xiàng)JMeter 屬性,以便修改日志級(jí)別。

            例如:我們可以點(diǎn)擊一個(gè)HTTP請(qǐng)求,選擇菜單欄“幫助”--->what's this node ?

           在jmeter的bin\目錄下,找到j(luò)meter.properties 文件,關(guān)于日志級(jí)別的屬性如下:

          #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

            搜索功能

            這是在使用一個(gè)變量或含有一定的URL或參數(shù)測(cè)試計(jì)劃樹和元素有時(shí)很難找到。現(xiàn)在一個(gè)新的特點(diǎn)是從2.6開始,你可以訪問它的菜單搜索。它提供了搜索與下列選項(xiàng):

            * 使搜索區(qū)分大小寫區(qū)分大小寫:

            * 正則表達(dá)式是一個(gè)正則表達(dá)式搜索文本,如果有的話將被搜索的正則表達(dá)式樹的組件,例如“\ BTEST \ b”將匹配任何組件,包含測(cè)試組件的搜索元素

            線程之間傳遞變量

            JMeter 變量作用域局限于所屬線程。這樣設(shè)計(jì)是經(jīng)過深思熟慮的,目的是讓測(cè)試線程能夠獨(dú)立運(yùn)轉(zhuǎn)。有時(shí)候用戶可能需要在不同線程間(可能屬于同一個(gè)線程組,也可能不屬于同一個(gè)線程組)傳遞變量。

            其中一種方法就是使用屬性。屬性為所有 JMeter 線程所共享,因此當(dāng)某個(gè)線程設(shè)置一個(gè)屬性后,其他線程就可以讀取更新后的值。

            如果存在大量數(shù)據(jù)需要在線程間傳遞,那么可以考慮使用文件。例如,測(cè)試人員可以在一個(gè)線程中使用監(jiān)聽器,保存響應(yīng)到文件(Save Responses to a file)或者 BeanShell PostProcessor 。而在另外一個(gè)線程中使用HTTP 采樣器的“file: ”協(xié)議來讀取文件,接著使用一個(gè)后置處理器或者BeanShell 測(cè)試元件提取信息。

            如果在測(cè)試啟動(dòng)前測(cè)試人員就能獲得測(cè)試數(shù)據(jù),那么最好將數(shù)據(jù)保存到文件中,使用CSV Dataset讀取。

            這最后一個(gè)技巧,操作較為麻煩,暫時(shí)不給詳細(xì)的例子。算是提供個(gè)思路吧!知道有這當(dāng)子事兒就行了。日后有機(jī)會(huì)再實(shí)踐^_^

          posted on 2013-01-11 11:09 順其自然EVO 閱讀(635) 評(píng)論(0)  編輯  收藏 所屬分類: jmeter and badboy

          <2013年1月>
          303112345
          6789101112
          13141516171819
          20212223242526
          272829303112
          3456789

          導(dǎo)航

          統(tǒng)計(jì)

          常用鏈接

          留言簿(55)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          最新評(píng)論

          閱讀排行榜

          評(píng)論排行榜

          主站蜘蛛池模板: 新巴尔虎右旗| 工布江达县| 巴青县| 莱西市| 胶州市| 辉南县| 隆子县| 涟水县| 无棣县| 子长县| 井陉县| 丹东市| 南安市| 富民县| 聂拉木县| 秦皇岛市| 肃宁县| 辽阳市| 石景山区| 拉萨市| 榕江县| 巩义市| 清水河县| 呼玛县| 英吉沙县| 江达县| 汤原县| 华阴市| 萍乡市| 噶尔县| 五大连池市| 鲜城| 仁化县| 成安县| 蓬安县| 西吉县| 房山区| 根河市| 昌乐县| 团风县| 安陆市|