JMeter測試工具使用_第1頁
JMeter測試工具使用_第2頁
JMeter測試工具使用_第3頁
JMeter測試工具使用_第4頁
JMeter測試工具使用_第5頁
已閱讀5頁,還剩19頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、JmeterJmeter基礎(chǔ)培訓(xùn)基礎(chǔ)培訓(xùn)報告人:質(zhì)量控制部 黃春 Judy Huang目錄第一部分 Jmeter簡介存拆庫項目性能測試第二部分 安裝Jmeter第四部分 腳本的錄制第五部分 腳本加工存拆庫項目性能測試第六部分 場景設(shè)置第八部分 遠程測試第十部分 Jemter Plugins第七部分 數(shù)據(jù)收集和展示第三部分 Jmeter組件第九部分 NON GUI模式3Jmeter簡介Jmeter是什么Apache JMeter 是Apache組織的開放源代碼項目,是一個100%純Java桌面應(yīng)用,用于壓力測試和性能測量。它最初被設(shè)計用于Web應(yīng)用測試但后來擴展到其它測試領(lǐng)域。我用它能做什么Ap

2、ache JMeter可以用于對靜態(tài)的和動態(tài)的資源(文件,Servlet,Perl腳本,Java對象,數(shù)據(jù)庫和查詢,F(xiàn)TP服務(wù)器或是其它資源)的性能進行測試。JMeter可以用于在服務(wù)器,網(wǎng)絡(luò)或?qū)ο竽M繁重的負載來測試它們提供服務(wù)的受壓能力或者分析不同壓力條件下的總體性能情況。你可以使用JMeter提供的圖形化界面,分析性能指標或者在高負載情況下測試你的服務(wù)器/腳本/對象。Jmeter能做什么能夠?qū)TTP和FTP服務(wù)器進行壓力和性能測試,也可以對任何數(shù)據(jù)庫進行同樣的測試(通過JDBC)。完全的可移植性和100%純Java。完全Swing的輕量級組件支持(預(yù)編譯的JAR使用 javax.swi

3、ng.*)包。完全多線程框架允許通過多個線程并發(fā)取樣和通過單獨的線程組對不同的功能同時取樣。精心的GUI設(shè)計允許快速操作和更精確的計時。緩存和離線分析/回放測試結(jié)果。高可擴展性:可鏈接的取樣器允許無限制的測試能力。各種負載統(tǒng)計表和可鏈接的計時器可供選擇。數(shù)據(jù)分析和可視化插件提供了很好的可擴展性以及個性化。具有提供動態(tài)輸入到測試的功能(包括JavaScript)。支持腳本變成的取樣器(在1.9.2及以上版本支持BeanShell)。4Jmeter安裝配置配置JDK從/download_jmeter.cgi下載, 解壓后運行bin目錄下的jmeter.

4、bat5Jmeter組件Thread Group: 場景的起始點,設(shè)置多少用戶并發(fā),什么時候開始跑,跑多久。Controllers: 包括Samplers和Logical Controllers。Samplers: 告訴Jmeter發(fā)請求和等待響應(yīng)。Logic Controllers: 組織發(fā)送請求的邏輯,例如什么情況下發(fā)請求,每個請求發(fā)多少次,多少百分比,順序是怎么樣的。Listener: 收集測試用例運行信息,例如響應(yīng)時間,請求和響應(yīng)的詳細信息。Timers:請求之間的暫停。Assertions: 驗證服務(wù)器返回的信息是否正確。Configuration Elements: 對sample

5、rs進行配置。Pre-Processor: 運行在Sampler之前,多用于設(shè)置sampler,和更新從上一個響應(yīng)獲得的變量值。Post-Processor: 運行在Sampler之后,多用于對響應(yīng)數(shù)據(jù)的處理。6Jmeter組件執(zhí)行順序:0.Configuration elements 1.Pre-Processors 2.Timers 3.Sampler 4.Post-Processors (unless SampleResult is null) 5.Assertions (unless SampleResult is null) 6.Listeners (unless SampleRes

6、ult is null) 只有有sampler 的時候,Timers, Assertions, Pre- and Post-Processors才會被運行, Logic Controllers and Samplers 按它們在樹里的排列順序執(zhí)行例子:Controller Post-Processor 1 Sampler 1 Sampler 2 Timer 1 Assertion 1 Pre-Processor 1 Timer 2 Post-Processor 2執(zhí)行的順序會是: Pre-Processor 1 Timer 1 Timer 2 Sampler 1 Post-Processor

7、1 Post-Processor 2 Assertion 1 Pre-Processor 1 Timer 1 Timer 2 Sampler 2 Post-Processor 1 Post-Processor 2 Assertion 1 7Jmeter組件作用域規(guī)則:Controllers的作用域是它的子元素其它組件是按等級來的,例如, 一個Assertion,如果它的父節(jié)點是請求,那它應(yīng)用于這個請求,如果它的父節(jié)點是Controller,那它應(yīng)用于Controller下面所有的請求。如圖,Assertion #1應(yīng)用于請求One, Assertion #2應(yīng)用于請求Two,Three。Tim

8、er#1應(yīng)用于請求Two,Three,Four, Assertion #1應(yīng)用于請求Three,Timer #2 應(yīng)用于所有請求。8錄制腳本 Step 1 工作臺添加一個HTTP代理服務(wù)器,用來錄腳本 Step 2 添加一個察看結(jié)果樹,用來觀察腳本錄制過程中產(chǎn)生的請求和響應(yīng)數(shù)據(jù) Step 3 線程組里面加一個錄制控制器,錄的請求會放在錄制控制器里 Step 4 瀏覽器的端口必須跟HTTP代理服務(wù)器設(shè)置的端口一樣 Step 5 啟動HTTP代理服務(wù)器,用瀏覽器打開要錄的接口 過濾掉或直接刪掉,例如.*.gif9腳本編輯關(guān)聯(lián)從上一個請求拿出要關(guān)聯(lián)的數(shù)據(jù),用正則表達式去匹配,例如要匹配的是id“:1

9、45 中的145,可以寫成id”:(.*?) 或 id“:(.+?) 或 id:(.*?).匹配任何字符*匹配0次或多次+匹配1交或多次?初次匹配成功后就停止/usermanual/regular_expressions.html有關(guān)于正則表達式寫法的描述。模板:$1$表示第一組匹配數(shù)字:1第一個匹配的,2第二個匹配的,0隨機取10腳本編輯參數(shù)化用CSV Date Set Config參數(shù)化每個線程的每個迭代用不同的值,線程調(diào)用這參數(shù)值的順序是他們執(zhí)行的順序決定的。Recycle on Eof=true,如果所有值被用完,就從頭開始取, Recyc

10、le on Eof=false時,stopThread才起作用Recycle on Eof=false,stopThread=false,當文件里面的所有的參數(shù)值被用完后,參數(shù)會被設(shè)為等于Recycle on Eof=false,stopThread=true,當文件里面的所有的參數(shù)值被用完后,場景就會停下來Delimiter 兩列參數(shù)之間的分隔符,默認是逗號,也可以設(shè)置為其它值A(chǔ)llow quote data CSV文件是否允許值被引號,如果是enabled,值可以被雙引號括起來(只允許雙引號,不允許單引號)如果想每個數(shù)據(jù)集有自己的數(shù)據(jù),可以使sharing mode = current t

11、hread, 需要為每個線程建一個文件(如果沒有,那么這個線程將不被執(zhí)行),例如 test1.csv, test2.csv,. testn.csv. 用這個文件名 test$_threadNum.csv11腳本編輯參數(shù)化用Jmeter自帶的方法參數(shù)化例如:$_StringFromFile(/home/vipshop/Jenkins/workspace/benchmarktest_cart.api/userEdit.csv,userEditID,)$_RandomString(9,chars,variableName)12腳本編輯HTTP Cookie 管理器有些請求會被重定向多次,因為我們沒有

12、維護user session, session要讀cookie,所以需要加上cookie manager.例如這個請求http:/ Cookie Manager加到每個Thread Group,可以每個thread擁有自己的cookies, 但是每個thread的所有Http請求會共享這個cookie13腳本編輯定時器Synchronizing Timer:等待到達一定數(shù)量的用戶數(shù)后才釋放用戶。0表示等齊所有用戶,10表示等齊10個用戶固定定時器:使每個thread在請求之間停頓相同的時間。14腳本編輯檢查點響應(yīng)斷言:為保證響應(yīng)數(shù)據(jù)的準確性,檢查響應(yīng)的數(shù)據(jù)是否包含,匹配,等于某個樣式字符串。1

13、5場景設(shè)置可根據(jù)場景的要求選擇controller用controller組織你的sampler吞吐量控制器,控制用戶執(zhí)行頻率Total Executions 當達到一定數(shù)量使控制器停止場景運行Percent executions 使控制器執(zhí)行test plan設(shè)定的一定百分比Per User 如果勾了,計算基于所有用戶一起執(zhí)行,如果不勾,計算基于單個用戶事務(wù)控制器,用于統(tǒng)計嵌套在transaction controller里面的所有元素的值(響應(yīng)時間,tps, 吞吐量等)Generate Parent Sample,如果勾了,這個控制器生成為其它sampler的父節(jié)點,否則獨立于其它sampl

14、erInclude duration of timer and pre-post processors in generated sample , 如果勾了,Transaction Controller的時間把timer和pre-post processors也計算在內(nèi),如果不勾,則不計算pre-post processors的時間16場景設(shè)置線程組線程組是設(shè)置計劃的開始點,所有controller和sampler都必需在線程組下面,其它元素可以直接放在test plan下面,用于同時應(yīng)用于所有的線程組,例如listener。ramp-up period:Jmeter花多少時間去啟動所有的線程

15、。如果有10個線程, ramp-up period是100秒,每個線程在上一個線程啟動10秒后才啟動當循環(huán)數(shù)達到循環(huán)次數(shù),時間達到結(jié)束時間或持續(xù)時間,場景會停止運行。啟動延遲的優(yōu)先級高于啟動時間,持續(xù)時間的優(yōu)先級高于結(jié)束時間17數(shù)據(jù)收集和展示Label:Sampler的名字Samples:請求個數(shù)Average:平均響應(yīng)時間,單位毫秒Median:中位數(shù),也就是 50 用戶不大于這個值,剩下的不小于這個值,單位毫秒90% Line:90 用戶不大于這個值,剩下的不小于這個值,單位毫秒Min:最小響應(yīng)時間,單位毫秒Max:最大響應(yīng)時間,單位毫秒Error%:本次測試中出現(xiàn)錯誤的請求的數(shù)量/請求的

16、總數(shù)Throughput:每秒完成的請求數(shù)Kb/Sec:每秒從服務(wù)器端接收到的數(shù)據(jù)量,Kilobytes per second, 相當于LoadRunner中的Throughput/SecAvg. Bytes: 請求的響應(yīng)數(shù)據(jù)的平均大小Std.Dev: Standard Deviation, 所有響應(yīng)時間標準偏差,反映數(shù)據(jù)波動,越小越好 18察看結(jié)果樹:以樹的形式顯示所有sampler的請求數(shù)據(jù)和響應(yīng)數(shù)據(jù),還可以看到接收響應(yīng)數(shù)據(jù)所花費的時間。由于使用它會消耗較多的資源,請只在調(diào)試和驗證腳本時使用。19遠程測試1.節(jié)點(節(jié)點包括client和server, client是調(diào)度機,server是被

17、調(diào)度機)最好用同一版本jmeter,如果用了數(shù)據(jù)文件,數(shù)據(jù)文件不會被client傳到server里,所以請保證數(shù)據(jù)文件存在于所有的server的正確目錄里。2.防火墻要關(guān)掉3.所有節(jié)點要在同一個子網(wǎng)4.一臺client啟動多臺server20遠程測試5. 在server上跑JMETER_HOME/bin/jmeter-server.bat6. 在/bin/perties里修改remote_hosts屬性,可設(shè)置多個host,用逗號隔開,例如remote_hosts=,821NON GUI模式Non GUI比GUI節(jié)省資源,并有更高

18、的穩(wěn)定性步驟:1. 進入jmeter的bin目錄2. 運行jmeter -n -t E:jmetertrainingexample.jmx -l E:jmetertrainingresult.jtl或jmeter -n -t E:jmetertrainingexample.jmx -l E:jmetertrainingresult.jtl -Jthreads 5 -Jiterations 4-n 這是指定JMeter在非用戶界面模式運行-t 包含測試計劃的JMX文件的名字:example.jmx-Jthreads 并發(fā)用戶數(shù):5個-Jiterations 循環(huán)次數(shù):4次-l 記錄取樣結(jié)果的JTL文件的名字:resut.jtl22Non GUI遠程測試jmeter -n -t D:paramexample.jmx -l D:paramresult.jtl -R ,4-R指定遠程的server, 可以不用在perities里配remote_hosts。相對路徑時,參數(shù)的csv要放在jme

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論