性能測試
為什么要進行性能測試?
評估當(dāng)前系統(tǒng)的能力
尋找性能瓶頸发魄,優(yōu)化系統(tǒng)性能
評估軟件是否滿足未來的需要
招聘需要
?什么是性能
時間:系統(tǒng)處理用戶請求的響應(yīng)時間
資源:系統(tǒng)運行過程中忠售,系統(tǒng)資源的消耗情況
性能測試是什么
?廣義定義
基于協(xié)議模擬用戶發(fā)出請求悔橄,對服務(wù)器形成一定負(fù)載缤底,來測試服務(wù)器的性能指標(biāo)是否滿足要求性能指標(biāo)關(guān)注點:時間性能扁耐、空間性能性能測試與頁面無關(guān)
?狹義定義
指通過自動化的測試工具模擬多種正常潦蝇、峰值以及異常負(fù)載條件來對系統(tǒng)的各項性能指標(biāo)進行測試款熬。
?功能和性能測試
不同
功能測試驗證系統(tǒng)的功能需求規(guī)格,聚焦功能攘乒。
性能測試驗證系統(tǒng)的業(yè)務(wù)性需求場景贤牛,聚焦時間和資源。
關(guān)系
一般項目中则酝,先功能測試通過后殉簸,后進行性能測試闰集。
性能測試的分類
基準(zhǔn)測試
狹義:單用戶測試
廣義:建立基準(zhǔn)線,當(dāng)系統(tǒng)軟硬件環(huán)境發(fā)生變化之后再進行一次基準(zhǔn)測試以確定變化對性能的影響般卑。
負(fù)載測試
概念
通過逐步增加系統(tǒng)負(fù)載武鲁,確定在滿足性能指標(biāo)的情況下,找出系統(tǒng)所能承受最大負(fù)載量的測試蝠检。
作用
系統(tǒng)最大負(fù)載量達(dá)到用戶要求時沐鼠,系統(tǒng)才能正式上線使用。
案例
電梯行業(yè)規(guī)范:電梯從1樓到5樓的運行時間不超過24s
1人? ? 20s7人? ? 20s13人? 20s? ? 達(dá)到最大負(fù)載16人? 25s19人? 28s21人? 斷繩子
注意
通過負(fù)載測試叹谁,可以確定系統(tǒng)的最大負(fù)載量和極限負(fù)載量
系統(tǒng)對外宣稱的最大負(fù)載量
負(fù)載測試的時間一般為1-2小時
?穩(wěn)定性測試
概念:在服務(wù)器穩(wěn)定運行(用戶正常業(yè)務(wù)負(fù)載下)的情況進行長時間測試(1天-一周等)饲梭,并最終保證服務(wù)器能滿足線上業(yè)務(wù)需求。
系統(tǒng)在用戶需求的業(yè)務(wù)負(fù)載下運行達(dá)到規(guī)定的時間時焰檩,系統(tǒng)才能正式上線使用憔涉。
?壓力測試
概念:在強負(fù)載下的測試,查看系統(tǒng)在峰值下是否功能隱患析苫、系統(tǒng)是否具有良好的容錯能力和可恢復(fù)的能力兜叨。
測試場景
高負(fù)載下的長時間穩(wěn)定性壓力測試 (如:B-C區(qū)間內(nèi)進行24/3*24小時長時間測試)
極限負(fù)載下的破壞性壓力測試(如:C-D區(qū)間內(nèi)進行測試)
并發(fā)測試
概念:在極短時間內(nèi),發(fā)送多個請求藤违,來驗證服務(wù)器對并發(fā)的處理能力浪腐。
應(yīng)用場景
特定的活動場景:搶紅包、秒殺顿乒、搶購等议街。
與負(fù)載測試對比:
負(fù)載測試:主要目的是測試高負(fù)載情況下,對系統(tǒng)資源的消耗璧榄,是否會耗盡的問題(雙11活動)
并發(fā)測試:主要目的是測試極短時間內(nèi)特漩,并發(fā)請求時,系統(tǒng)資源爭搶的問題(搶紅包骨杂、秒殺)
?性能測試的指標(biāo)
響應(yīng)時間
指從客戶端發(fā)起請求開始涂身,到客戶端接收到結(jié)果的總時間
包括:服務(wù)器處理時間 + 網(wǎng)絡(luò)傳輸時間
?并發(fā)用戶數(shù)
某一時刻同時向服務(wù)器發(fā)送請求的用戶數(shù)
?吞吐量(Throughout)
1.概念:單位時間內(nèi)處理客戶端的請求數(shù)量,直接體現(xiàn)軟件系統(tǒng)能能承載能力搓蚪。
吞吐量單位分類
?QPS
QPS(Query Per Second)每秒查詢數(shù)蛤售,即控制服務(wù)器每秒處理的指定請求的數(shù)量。
TPS
TPS(Transaction Per Second)每秒事務(wù)數(shù)妒潭,即控制服務(wù)器每秒處理事務(wù)請求的數(shù)量悴能。
如:支付請求事務(wù)=查詢用戶余額請求+校驗支付安全請求+發(fā)送支付請求
每秒處理查詢用戶余額15請求,每秒處理校驗支付安全15個請求雳灾,每秒處理發(fā)送支付15個請求
支付tsp為15
點擊數(shù)
所有的頁面元素(如:圖片漠酿、鏈接、框架等)的請求總數(shù)量
注意:
點擊數(shù)是請求數(shù)谎亩,不是頁面上的一次點擊
?錯誤率
指系統(tǒng)在負(fù)載情況下炒嘲,失敗業(yè)務(wù)的概率
注意:
錯誤率是性能指標(biāo)宇姚,是高負(fù)載下的失敗業(yè)務(wù)的概率
-隨機bug是功能bug,先解決隨機bug才能進行性能測試
?資源利用率
概念:系統(tǒng)各種資源的使用情況夫凸,率=資源使用量/總資源可用量x100%
常見資源指標(biāo)
CPU使用率:不高于75%-85%
內(nèi)存大小使用率:不高于80%
磁盤IO(速率):不高于90%
網(wǎng)路(速率):不高于80%
性能測試工具
?Jmeter簡介
?我們?yōu)槭裁词褂肑meter
開源浑劳,免費,基于Java編寫寸痢,可集成到其他系統(tǒng)可拓展各個功能插件
支持接口測試呀洲,壓力(負(fù)載和壓力)測試等多種功能,支持錄制回放啼止,
入門簡單相較于自己編寫框架活其他開源工具道逗,有較為完善的UI界面,便于接口調(diào)試
多平臺支持献烦,可在Linux滓窍,Windows,Mac上運行巩那,支持多協(xié)議
?Jmeter的作用
接口測試? 面試說postman吏夯,因為方便好用。
性能測試? jmeter即横,也可以用postman(runner)噪生,但是沒有性能指標(biāo)
數(shù)據(jù)庫測試
?Jmeter怎么用
Windows下Jmeter下載安裝,登錄http://jmeter.apache.org/download_jmeter.cgi东囚,根據(jù)自己平臺跺嗽,下載對應(yīng)文件
安裝JAVA環(huán)境
安裝JDK,配置環(huán)境變量(具體步驟不做介紹)
將下載Jmeter文件解壓页藻,打開/bin/jmeter.bat
?Jmeter的目錄結(jié)構(gòu)
/bin 目錄常用文件介紹:
examples:目錄下包含Jmeter使用實例ApacheJMeter.jar:JMeter源碼包jmeter.bat:windows下啟動文件jmeter.sh:Linux下啟動文件jmeter.log:Jmeter運行日志文件jmeter.properties:Jmeter配置文件jmeter-server.bat:windows下啟動負(fù)載生成器服務(wù)文件jmeter-server:Linux下啟動負(fù)載生成器文件/docs目錄——Jmeter幫助文檔/extras目錄——提供了對Ant的支持文件桨嫁,可也用于持續(xù)集成/lib目錄——存放Jmeter依賴的jar包,同時安裝插件也放于此目錄/licenses目錄——軟件許可文件份帐,不用管/printable_docs目錄——Jmeter用戶手冊
?使用Jmeter測試快速入門
線程組是什么
進程: 一個正在執(zhí)行的程序?qū)?yīng)一個進程線程: 一個進程有多個執(zhí)行線程線程組:? 按照線程性質(zhì)對線程分組璃吧。查看任務(wù)管理器(愛奇藝有多個)三者關(guān)系: 一個進程有多個線程組,一個線程組有多個線程
測試計劃—線程組—線程組屬性中的線程數(shù)
并發(fā)執(zhí)行:多個線程同時執(zhí)行废境,特點:執(zhí)行結(jié)束的順序與開始的順序不一致
順序執(zhí)行:按照線程的啟動順序挨個執(zhí)行
默認(rèn)情況下畜挨,線程組中的線程是并發(fā)執(zhí)行
每一個線程都要執(zhí)行組內(nèi)的http請求
設(shè)置線程組順序執(zhí)行:勾選測試計劃中的(獨立運行每個線程組)
線程組用來模擬用戶的并發(fā)訪問
創(chuàng)建線程組
?線程組主要包含三個參數(shù):
線程數(shù)、準(zhǔn)備時長(Ramp-Up Period(in seconds))噩凹、循環(huán)次數(shù)朦促。
線程數(shù):
虛擬用戶數(shù)。一個虛擬用戶占用一個線程栓始。設(shè)置多少虛擬用戶數(shù)在這里也就是設(shè)置多少個線程數(shù)。
?準(zhǔn)備時長(秒):
設(shè)置的虛擬用戶數(shù)需要多長時間全部啟動血当。如果線程數(shù)為20 幻赚,準(zhǔn)備時長為10 禀忆,那么需要10秒鐘啟動20個線程。也就是每秒鐘啟動2個線程落恼。
循環(huán)次數(shù):
每個線程發(fā)送請求的次數(shù)箩退。如果線程數(shù)為20 ,循環(huán)次數(shù)為100 佳谦,那么每個線程發(fā)送100次請求戴涝。總請求數(shù)為20*100=2000 钻蔑。如果勾選了“永遠(yuǎn)”啥刻,那么所有線程會一直發(fā)送請求,一直到選擇停止運行腳本咪笑。
?調(diào)度器
設(shè)置線程組啟動的開始時間和結(jié)束時間(配置調(diào)度器時可帽,需要勾選循環(huán)次數(shù)為永遠(yuǎn))
持續(xù)時間(秒)
測試持續(xù)時間,會覆蓋結(jié)束時間
啟動延遲(秒)
測試延遲啟動時間窗怒,會覆蓋啟動時間
啟動時間
測試啟動時間映跟,啟動延遲會覆蓋它。當(dāng)啟動時間已過扬虚,手動只需測試時當(dāng)前時間也會覆蓋它努隙。
?結(jié)束時間
測試結(jié)束時間,持續(xù)時間會覆蓋它辜昵。
?創(chuàng)建http請求
指定請求域名荸镊,請求路徑
一個HTTP請求有著許多的配置參數(shù),下面將詳細(xì)介紹:
名稱:本屬性用于標(biāo)識一個取樣器路鹰,建議使用一個有意義的名稱贷洲。
注釋:對于測試沒有任何作用,僅用戶記錄用戶可讀的注釋信息晋柱。
服務(wù)器名稱或IP :HTTP請求發(fā)送的目標(biāo)服務(wù)器名稱或IP地址优构。
端口號:目標(biāo)服務(wù)器的端口號。
方法:發(fā)送HTTP請求的方法雁竞,可用方法包括GET钦椭、POST、HEAD碑诉、PUT彪腔、OPTIONS、TRACE进栽、DELETE等德挣。
Content encoding :內(nèi)容的編碼方式,默認(rèn)值為iso8859
路徑:目標(biāo)URL路徑(不包括服務(wù)器地址和端口)
點擊run測試快毛,很麻煩格嗅,我們使用postman測試更簡單番挺,使用postman操作。
可以使用剛才的接口文檔中的屯掖,聚合接口中演示一個玄柏。
設(shè)置對應(yīng)的查看內(nèi)容
注意:如果監(jiān)聽器中有jp@gc開頭的,都是第三方插件
查看表格信息
Sample:每個請求的序號
Start Time:每個請求開始時間
Thread Name:每個線程的名稱
Label:Http請求名稱
Sample Time:每個請求所花時間贴铜,單位毫秒
Status:請求狀態(tài)粪摘,如果為勾則表示成功,如果為叉表示失敗绍坝。
Bytes:請求的字節(jié)數(shù)
樣本數(shù)目:也就是上面所說的請求個數(shù)徘意,成功的情況下等于你設(shè)定的并發(fā)數(shù)目乘以循環(huán)次數(shù)
平均:每個線程請求的平均時間
最新樣本:表示服務(wù)器響應(yīng)最后一個請求的時間
偏離:服務(wù)器響應(yīng)時間變化、離散程度測量值的大小陷嘴,或者映砖,換句話說,就是數(shù)據(jù)的分布灾挨。
查看結(jié)果樹
請求的數(shù)據(jù)展示(請求頭信息邑退,請求參數(shù),,)
響應(yīng)的數(shù)據(jù)展示(響應(yīng)碼,響應(yīng)頭,,)
通過察看結(jié)果樹劳澄,我們可以看到每個請求的結(jié)果地技,其中紅色的是出錯的請求,綠色的為通過秒拔。
Thread Name:線程組名稱Sample Start:啟動開始時間Load time:加載時長Latency:等待時長Sizeinbytes:發(fā)送的數(shù)據(jù)總大小Headers sizeinbytes:發(fā)送數(shù)據(jù)的其余部分大小Sample Count:發(fā)送統(tǒng)計Error Count:交互錯誤統(tǒng)計Response code:返回碼Response message:返回信息Response headers:返回的頭部信息
?聚合報告參數(shù)說明
lable:對應(yīng)每一個http請求莫矗,顯示的是http請求的Name,如百度http請求name為baidu
#Samples:表示這一次的測試中一共發(fā)出了多少請求砂缩,如上圖所示作谚,sougou和baidu的http請求每個都發(fā)出30個請求
Average:平均響應(yīng)時間,指的是所有的請求的平均響應(yīng)時間庵芭,如上圖的30個請求的總的響應(yīng)時間除以30得出的平均響應(yīng)時間妹懒,默認(rèn)的情況下是單個請求的平均響應(yīng)時間,但當(dāng)使用了“事務(wù)控制器”時双吆,則以事物為單位顯示平均響應(yīng)時間
Median:中位數(shù)眨唬,也就是50%用戶的響應(yīng)時間
90%Line:90%用戶的響應(yīng)時間
Min:最小響應(yīng)時間
Max:最大的響應(yīng)時間
Error%:本次測試中出現(xiàn)錯誤的請求的數(shù)量/請求的總數(shù),如上圖所示好乐,本次的測試中匾竿,sougou的http請求66.6%的請求出錯,而baidu的請求則沒有出錯的請求
Throughput:吞吐量蔚万,默認(rèn)情況下表示每秒完成的請求數(shù)岭妖,如上圖所示,每秒完成的請求數(shù)分別為6.6個每秒,6.2個每秒
Recived KB/Sec:每秒從服務(wù)器端接收到的數(shù)據(jù)量昵慌,以kb為計算的單位
掌握:平均時間苔巨、錯誤率、吞吐量废离。
?圖形結(jié)果
作用:通過圖形展示出本次性能測試數(shù)據(jù)的分布。 圖形結(jié)果一般作為聚合報告的分析輔佐
樣本數(shù)目:總共發(fā)送到服務(wù)器的請求數(shù)礁芦。最新樣本:代表時間的數(shù)字蜻韭,是服務(wù)器響應(yīng)最后一個請求的時間。吞吐量:服務(wù)器每分鐘處理的請求數(shù)柿扣。平均值:總運行時間除以發(fā)送到服務(wù)器的請求數(shù)肖方。中間值:有一半的服務(wù)器響應(yīng)時間低于該值而另一半高于該值。偏離:表示服務(wù)器響應(yīng)時間變化未状、離散程度測量值的大小俯画。
?Jmeter主要組件介紹
測試計劃:使用 JMeter 進行測試的起點,它是其它 JMeter 測試元件的容器司草。
線程組:代表一定數(shù)量的并發(fā)用戶艰垂,它可以用來模擬并發(fā)用戶發(fā)送請求。實際的請求內(nèi)容在Sampler中定義埋虹,它被線程組包含猜憎。可以在“測試計劃->添加->線程組”來建立它搔课,然后在線程組面板里有幾個輸入欄:線程數(shù)胰柑、Ramp-Up Period(in seconds)、循環(huán)次數(shù)爬泥,其中Ramp-Up Period(in seconds)表示在這時間內(nèi)創(chuàng)建完所有的線程柬讨。如有8個線程,Ramp-Up = 200秒袍啡,那么線程的啟動時間間隔為200/8=25秒踩官,這樣的好處是:一開始不會對服務(wù)器有太大的負(fù)載。線程組是為模擬并發(fā)負(fù)載而設(shè)計葬馋。
取樣器(Sampler):模擬各種請求卖鲤。所有實際的測試任務(wù)都由取樣器承擔(dān),存在很多種請求畴嘶。如:HTTP 蛋逾、ftp請求等等。
監(jiān)聽器:負(fù)責(zé)收集測試結(jié)果窗悯,同時也被告知了結(jié)果顯示的方式区匣。功能是對取樣器的請求結(jié)果顯示、統(tǒng)計一些數(shù)據(jù)(吞吐量、KB/S……)等亏钩。
斷言:用于來判斷請求響應(yīng)的結(jié)果是否如用戶所期望莲绰,是否正確。它可以用來隔離問題域姑丑,即在確保功能正確的前提下執(zhí)行壓力測試蛤签。這個限制對于有效的測試是非常有用的。
邏輯控制器:允許自定義JMeter發(fā)送請求的行為邏輯栅哀,它與Sampler結(jié)合使用可以模擬復(fù)雜的請求序列震肮。
定時器:負(fù)責(zé)定義請求(線程)之間的延遲間隔,模擬對服務(wù)器的連續(xù)請求留拾。
配置元件維護Sampler需要的配置信息戳晌,并根據(jù)實際的需要會修改請求的內(nèi)容。
前置處理器和后置處理器負(fù)責(zé)在生成請求之前和之后完成工作痴柔。前置處理器常常用來修改請求的設(shè)置沦偎,后置處理器則常常用來處理響應(yīng)的數(shù)據(jù)。
測試計劃
1.測試計劃就是一個完整的場景2.“獨立運行每個線程組” :勾選以后所有的線程組都是順序執(zhí)行的了咳蔚。一般不勾選豪嚎,讓所有 的線程組并發(fā)啟動。3.“函數(shù)測試模式” :勾選后會有詳細(xì)的請求記錄屹篓,消耗資源疙渣,影響客戶端性能。一般不勾選堆巧。4.用戶定義的變量:全局變量妄荔,測試計劃上可以添加用戶定義的變量。一般添加一些系統(tǒng)常用的配置谍肤。如果測試過程中想切換環(huán)境啦租,切換配置,一般不建議在測試計劃上添加變量
?線程組
(1)thread group(線程組)
這個就是我們通常添加運行的線程荒揣。通俗的講一個線程組篷角,可以看做一個虛擬用戶組,線程組中的每個線程都可以理解為一個虛擬用戶系任。
(2)setup thread group
一種特殊類型的ThreadGroup的恳蹲,可用于執(zhí)行預(yù)測試操作。這些線程的行為完全像一個正常的線程組元件俩滥。不同的是嘉蕾,這些類型的線程執(zhí)行測試前進行定期線程組的執(zhí)行;類似LoadRunner的init霜旧,測試開始時進行初始化的工作错忱。
(3)teardown thread group
一種特殊類型的ThreadGroup的,可用于執(zhí)行測試后動作。這些線程的行為完全像一個正常的線程組元件以清。不同的是儿普,這些類型的線程執(zhí)行測試結(jié)束后執(zhí)行定期的線程組;類似LoadRunnner的end掷倔,測試結(jié)束時進行回收工作眉孩。
取樣器(Http請求)
關(guān)于http請求的的屬性參數(shù)說明:
1)名稱:用于標(biāo)識一個sample。建議使用一個有意義的名稱2)注釋:對于測試沒任何影響勒葱,僅用來記錄用戶可讀的注釋信息3)服務(wù)器名稱或IP:http請求發(fā)送的目標(biāo)服務(wù)器名稱或者IP地址勺像,比如http://www.baidu.com4)端口號:目標(biāo)服務(wù)器的端口號,默認(rèn)值為80错森,可不填5)協(xié)議:向目標(biāo)服務(wù)器發(fā)送http請求時的協(xié)議,http/https篮洁,大小寫不敏感涩维,默認(rèn)http6)方法:發(fā)送http請求的方法(鏈接:http://www.cnblogs.com/imyalost/p/5630940.html)7)Contentencoding:內(nèi)容的編碼方式(Content-Type=application/json;charset=utf-8)8)路徑:目標(biāo)的URL路徑(不包括服務(wù)器地址和端口)9)自動重定向:如果選中該項,發(fā)出的http請求得到響應(yīng)是301/302袁波,jmeter會重定向到新的界面10)Usekeep Alive:jmeter 和目標(biāo)服務(wù)器之間使用 Keep-Alive方式進行HTTP通信(默認(rèn)選中)11)Usemultipart/from-dataforHTTPPOST :當(dāng)發(fā)送HTTPPOST 請求時瓦阐,使用12)Parameters、BodyData以及FilesUpload的區(qū)別:1.parameter是指函數(shù)定義中參數(shù)篷牌,而argument指的是函數(shù)調(diào)用時的實際參數(shù)2.簡略描述為:parameter=形參(formal parameter)睡蟋, argument=實參(actual parameter)3.在不很嚴(yán)格的情況下,現(xiàn)在二者可以混用枷颊,一般用argument戳杀,而parameter則比較少用Whiledefining method,variables passedinthe method are called parameters.當(dāng)定義方法時,傳遞到方法中的變量稱為參數(shù).Whileusingthose methods,values passed to those variables are called arguments.當(dāng)調(diào)用方法時夭苗,傳給變量的值稱為引數(shù).(有時argument被翻譯為“引數(shù)“)4信卡、BodyData指的是實體數(shù)據(jù),就是請求報文里面主體實體的內(nèi)容题造,一般我們向服務(wù)器發(fā)送請求傍菇,攜帶的實體主體參數(shù),可以寫入這里5界赔、FilesUpload指的是:從HTML文件獲取所有有內(nèi)含的資源:被選中時丢习,發(fā)出HTTP請求并獲得響應(yīng)的HTML文件內(nèi)容后還對該HTML? 進行Parse 并獲取HTML中包含的所有資源(圖片、flash等):(默認(rèn)不選中)? 如果用戶只希望獲取特定資源淮悼,可以在下方的EmbeddedURLsmust match 文本框中填入需要下載的特定資源表達(dá)式咐低,只有能匹配指定正則表達(dá)式的URL指向資源會被下載
?監(jiān)聽器
監(jiān)聽器(Listener)負(fù)責(zé)收集測試結(jié)果,同時也被告知了結(jié)果顯示的方式敛惊。我們常用的包括:聚合報告渊鞋、查看結(jié)果樹、用表格查看結(jié)果,都支持將結(jié)果數(shù)據(jù)寫入文件锡宋。其他的添加上去看看就行儡湾。聚合報告前面我們介紹過,后面是查看結(jié)果樹和用表格查看結(jié)果的截圖执俩。
循環(huán)控制器
事務(wù)控制器
作用: 事務(wù)控制器會生產(chǎn)一個額外的采樣器徐钠,用來統(tǒng)計該控制器子結(jié)點的所有時間。
在線程組下創(chuàng)建事務(wù)控制器
參數(shù):
· Generate parent sample:(選中這個參數(shù)結(jié)果展示如下圖紅框役首,否則顯示為下圖藍(lán)框)
· Include duration of timer and pre-post processors in generated sample:選中這一項會統(tǒng)計定時器(timer)的時間尝丐,否則只統(tǒng)計采樣器(sample)的時間
創(chuàng)建sample 訪問首頁和注冊頁面
生成聚合報告
勾選
聚合報告中只有一項事務(wù)報告
斷言---檢查點
斷言(Assertions)可以用來判斷請求響應(yīng)的結(jié)果是否如用戶所期望的。它可以用來隔離問題域衡奥,即在確保功能正確的前提下執(zhí)行壓力測試爹袁。這個限制對于有效的測試是非常有用的。
兩個重要斷言:響應(yīng)斷言和JSONAssertion
響應(yīng)斷言:
JSON斷言:
前置處理器和后置處理器
前置處理器(Pre Processors)和后置處理器(Post Processors)負(fù)責(zé)在生成請求之前和之后完成工作矮固。前置處理器常常用來修改請求的設(shè)置失息,后置處理器則常常用來處理響應(yīng)的數(shù)據(jù)。我們主要在動態(tài)關(guān)聯(lián)中用到后置處理器的正則表達(dá)式提取器档址。
https://www.cnblogs.com/fengpingfan/p/4755411.html
?定時器
定時器(Timer)負(fù)責(zé)定義請求之間的延遲間隔
Jmeter組件參數(shù)化
參數(shù)化是什么
動態(tài)的獲取并設(shè)置數(shù)據(jù)
為什么使用參數(shù)化
執(zhí)行批量操作盹兢,批量添加批量刪除,人工效率太低運用程序代替人工獲取并設(shè)置數(shù)據(jù)守伸,安全高效比如:對被測系統(tǒng)的用戶名和密碼進行參數(shù)化绎秒,來模擬多個用戶同時登錄系統(tǒng)
參數(shù)化實現(xiàn)之用戶自定義變量
通過這個功能,能實現(xiàn)多接口共享數(shù)據(jù)尼摹,修改一條即可修改全部
Filename:所需數(shù)據(jù)文件的路徑见芹。如和腳本同一路徑,可直接填寫文件名
File encoding:編碼和文件保持一致即可蠢涝,默認(rèn)為ANSI辆童。如有中文,建議為UTF-8
Variable Names:引用變量時的變量名惠赫,對應(yīng)數(shù)據(jù)文件中的每一列把鉴,以逗號分隔。如不填寫儿咱,文件的第一行數(shù)據(jù)將被讀取為變量名
Delimiter:在.txt庭砍、.dat文件中,可以用逗號(,)或者Tab鍵(\t)來區(qū)分列與列
Allow quote data:選項選為“true”的時候?qū)θ亲址奶幚沓霈F(xiàn)亂碼
Recycle on EOF:到數(shù)據(jù)文件結(jié)尾時是否循環(huán)讀取混埠。設(shè)置為True時怠缸,線程數(shù)過多,數(shù)據(jù)文件讀取到最后一行時钳宪,會再次從第一行開始讀取揭北。設(shè)置為False扳炬,到達(dá)文件結(jié)尾時如繼續(xù)讀取,則值會默認(rèn)為搔体,可通過設(shè)置jmeter屬性csvdataset.eofstring來改變該值恨樟。
Stop thread on EOF:Recycle on EOF設(shè)置為False,Stop thread on EOF設(shè)置為True疚俱,則讀取數(shù)據(jù)文件最后一行后劝术,停止測試,不管還有多少線程組未執(zhí)行呆奕。
Sharing mode:共享模式养晋。默認(rèn)在所有線程組中使用,可選擇每個線程組單獨打開
相同的部分使用用戶自定義變量
只需要修改一次接口
效果展示
參數(shù)化實現(xiàn)之CSV Data Set Config
添加CSV Data Set Config:
添加界面:
通過這個組件可以動態(tài)獲取并設(shè)置數(shù)據(jù)梁钾,實現(xiàn)批量添加操作
名詞解釋:
Filename:所需數(shù)據(jù)文件的路徑绳泉。如和腳本同一路徑,可直接填寫文件名Fileencoding:編碼和文件保持一致即可姆泻,默認(rèn)為ANSI圈纺。如有中文,建議為UTF-8VariableNames:引用變量時的變量名麦射,對應(yīng)數(shù)據(jù)文件中的每一列,以逗號分隔灯谣。Delimiter:在.txt潜秋、.dat文件中,可以用逗號(,)或者Tab鍵(\t)來區(qū)分列與列Allowquote data:選項選為“true”的時候?qū)θ亲址奶幚沓霈F(xiàn)亂碼Recycleon EOF:到數(shù)據(jù)文件結(jié)尾時是否循環(huán)讀取胎许。設(shè)置為True時峻呛,線程數(shù)過多,數(shù)據(jù)文件讀取到最后一行時辜窑,會再次從第一行開始讀取钩述。設(shè)置為False涕蚤,到達(dá)文件結(jié)尾時如繼續(xù)讀取威蕉,則值會默認(rèn)為<EOF>,可通過設(shè)置jmeter屬性csvdataset.eofstring來改變該值揩尸。Stopthread on EOF:Recycleon EOF設(shè)置為False所禀,Stopthread on EOF設(shè)置為True方面,則讀取數(shù)據(jù)文件最后一行后,停止測試色徘,不管還有多少線程組未執(zhí)行恭金。Sharingmode:共享模式。默認(rèn)在所有線程組中使用褂策,可選擇每個線程組單獨打開
添加引用文件:
引用:
在jmeter中添加
線程數(shù)改為某個值
查看結(jié)果樹:
其他:
線程組線程數(shù)改為大于文件中數(shù)據(jù)的處理:
遇到結(jié)束符在循環(huán)
遇到結(jié)束符停止線程
如果數(shù)據(jù)來自數(shù)據(jù)庫
數(shù)據(jù)庫導(dǎo)出txt文件
?使用Jmeter函數(shù)助手(文件中不要出現(xiàn)中文):
1横腿、點擊 選項-->函數(shù)助手 調(diào)出函數(shù)助手對話框2颓屑、選擇 _CSVRead 函數(shù)(下圖第一個框)3、函數(shù)參數(shù):1)第一個參數(shù):填寫文件路徑耿焊。2)第二個參數(shù):文件列號是從0開始的揪惦,第一列0、第二列1搀别、第三列2丹擎、依次類推,然后點擊【生成】按鈕,則會自動生成我們需要的參數(shù)化函數(shù)歇父。3)復(fù)制生成的參數(shù)化函數(shù)蒂培,copy過程需要使用的地方即可。4)_Random函數(shù)是從某數(shù)據(jù)段隨機讀取數(shù)據(jù)替換參數(shù)榜苫,當(dāng)需要添加多條數(shù)據(jù)記錄且某些字段需要唯一性時使用护戳。
Jmeter正則表達(dá)式提取
使用正則提取
運用Jmeter正則提取器,可以從請求的響應(yīng)結(jié)果中取到需要的內(nèi)容垂睬,從而實現(xiàn)關(guān)聯(lián)媳荒。關(guān)聯(lián)是請求與請求之間存在數(shù)據(jù)依賴關(guān)系,需要從上一個請求獲取下一個請求需要回傳回去的數(shù)據(jù)
正則表達(dá)式(regular expression)描述了一種字符串匹配的模式(pattern)驹饺,可以用來檢查一個串是否含有某種子串钳枕、將匹配的子串替換或者從某個串中取出符合某個條件的子串等。
字符描述
*匹配前面的子表達(dá)式零次或多次赏壹。例如鱼炒,zo* 能匹配 "z" 以及 "zoo"。* 等價于{0,}蝌借。
+匹配前面的子表達(dá)式一次或多次昔瞧。例如,'zo+' 能匹配 "zo" 以及 "zoo"菩佑,但不能匹配 "z"自晰。+ 等價于 {1,}。
?匹配前面的子表達(dá)式零次或一次稍坯。例如酬荞,"do(es)?" 可以匹配 "do" 、 "does" 中的 "does" 瞧哟、 "doxy" 中的 "do" 袜蚕。? 等價于 {0,1}。
( )標(biāo)記一個子表達(dá)式的開始和結(jié)束位置绢涡。子表達(dá)式可以獲取供以后使用牲剃。
.匹配除換行符 \n 之外的任何單字符。要匹配 . 雄可,請使用 . 凿傅。
構(gòu)造正則表達(dá)式的方法和創(chuàng)建數(shù)學(xué)表達(dá)式的方法一樣缠犀。也就是用多種元字符與運算符可以將小的表達(dá)式結(jié)合在一起來創(chuàng)建更大的表達(dá)式。正則表達(dá)式的組件可以是單個的字符聪舒、字符集合辨液、字符范圍、字符間的選擇或者所有這些組件的任意組合箱残。
正則表達(dá)式提取的相關(guān)設(shè)置
說明:
(1)引用名稱:下一個請求要引用的參數(shù)名稱滔迈,如填寫title,則可用${title}引用它被辑。(2)正則表達(dá)式:():括起來的部分就是要提取的燎悍。.:匹配任何字符串。+:一次或多次盼理。?:不要太貪婪谈山,在找到第一個匹配項后停止。(3)模板:用$$引用起來宏怔,如果在正則表達(dá)式中有多個正則表達(dá)式奏路,則可以是$2$$3$等等,表示解析到的第幾個值給title臊诊。如:$1$表示解析到的第1個值(4)匹配數(shù)字:0代表隨機取值鸽粉,1代表全部取值,通常情況下填0(5)缺省值:如果參數(shù)沒有取得到值抓艳,那默認(rèn)給一個值讓它取触机。
案例:api接口