很多JMeter用戶,尤其是初學(xué)者,往往止步于最簡(jiǎn)單的“線程組”->“HTTP請(qǐng)求”->“查看結(jié)果樹(shù)”的工作流。這就像擁有一把瑞士軍刀卻只用來(lái)開(kāi)瓶蓋,完全浪費(fèi)了它的強(qiáng)大潛力。
![]()
事實(shí)上,JMeter內(nèi)置了大量高效、實(shí)用的元件,掌握它們不僅能讓你從重復(fù)勞動(dòng)中解放出來(lái),更能讓你設(shè)計(jì)出專業(yè)級(jí)、易維護(hù)、高復(fù)用的性能測(cè)試腳本。本文將帶你揭秘那些被嚴(yán)重低估的JMeter神器元件,用過(guò)之后你只會(huì)感嘆:為什么沒(méi)早點(diǎn)知道!
![]()
1、用戶定義的變量
(User Defined Variables)
- 腳本的“控制臺(tái)”
新手做法:將域名、端口、路徑等參數(shù)寫(xiě)死在每一個(gè)HTTP請(qǐng)求中。切換環(huán)境?準(zhǔn)備用到令人頭皮發(fā)麻的“查找替換”功能吧!
高手做法:使用用戶定義的變量集中管理所有配置。
使用方法:
在線程組起始位置右鍵 -> 添加 -> 配置元件 -> 用戶定義的變量
在表格中定義你的變量,例如:
![]()
在所有HTTP請(qǐng)求的“路徑”欄中,你不再填寫(xiě)完整的URL,而是使用${protocol}://${domain}:${port}${version}/login 這種形式。
推薦原因:
當(dāng)需要從測(cè)試環(huán)境切換到生產(chǎn)環(huán)境時(shí),你只需要在這個(gè)元件里修改一次domain的值(例如改為 api.your-app-prod.com),整個(gè)腳本的所有請(qǐng)求就全部自動(dòng)生效!只需改這一個(gè)地方!維護(hù)腳本的效率提升10086倍。
2、JSR223處理器- 動(dòng)態(tài)處理的終極瑞士軍刀
新手做法:遇到復(fù)雜的動(dòng)態(tài)數(shù)據(jù)(如加密簽名、MD5、復(fù)雜斷言)時(shí),試圖用各種內(nèi)置配置元件(如BeanShell、函數(shù)助手)拼湊實(shí)現(xiàn),或者干脆選擇放棄,無(wú)法完成真實(shí)的測(cè)試場(chǎng)景。腳本變得臃腫、低效且難以維護(hù)。
高手做法:使用JSR223處理器并選擇Groovy作為語(yǔ)言,用幾行代碼輕松解決一切動(dòng)態(tài)數(shù)據(jù)處理難題。Groovy語(yǔ)法類似Java但更簡(jiǎn)潔,且性能遠(yuǎn)超BeanShell,是JMeter中執(zhí)行自定義邏輯的首選。
使用方法:
位置:JSR223 PreProcessor:在請(qǐng)求發(fā)送前執(zhí)行,用于生成或處理參數(shù)。
JSR223 PostProcessor:在請(qǐng)求返回后執(zhí)行,用于提取或驗(yàn)證響應(yīng)數(shù)據(jù)。
添加方法:在某個(gè)HTTP請(qǐng)求或節(jié)點(diǎn)上右鍵->添加->預(yù)處理器/后置處理器->JSR223 PreProcessor/JSR223
PostProcessor。
![]()
Language:必須選擇 groovy。
Parameters:傳遞給腳本的參數(shù)(可選)。
Script:在下方的編輯框中編寫(xiě)你的Groovy代碼。
![]()
3、吞吐量控制器- 控制業(yè)務(wù)比例的金手指
新手做法:認(rèn)為“線程數(shù)”和“循環(huán)次數(shù)”就能模擬所有場(chǎng)景,無(wú)法精確控制不同業(yè)務(wù)操作的比例。
高手做法:使用吞吐量控制器精確控制不同請(qǐng)求的執(zhí)行頻率。
使用方法:
3.1、右鍵線程組->添加->邏輯控制器->吞吐量控制器
3.2、將需要控制的請(qǐng)求(如“瀏覽商品”、“提交訂單”)放到其下面。
3.3、選擇“百分比吞吐量”,并設(shè)置比例。
Eg:一個(gè)電商場(chǎng)景中,100%的用戶會(huì)瀏覽商品,但只有30%的用戶會(huì)添加購(gòu)物車,最后只有10%的用戶會(huì)真正下單。就可以這樣設(shè)置:
一個(gè)吞吐量控制器(100%)->瀏覽商品請(qǐng)求
一個(gè)吞吐量控制器(30%)->添加購(gòu)物車請(qǐng)求
一個(gè)吞吐量控制器(10%)->提交訂單請(qǐng)求
![]()
它控制的是執(zhí)行次數(shù)占總迭代次數(shù)的百分比,而不是線程數(shù)。這能極其真實(shí)地模擬出線上業(yè)務(wù)的實(shí)際壓力模型,讓你的壓測(cè)結(jié)果可信度飆升。
4、事務(wù)控制器- 業(yè)務(wù)性能的真實(shí)度量衡
新手做法:在測(cè)試報(bào)告中只關(guān)注單個(gè)請(qǐng)求的響應(yīng)時(shí)間(如“登錄”、“查詢商品”、“下單”各自花了多久)。但用戶感知的是一個(gè)完整操作的耗時(shí),比如“從登錄到成功下單”總共花了多少時(shí)間。單獨(dú)看每個(gè)請(qǐng)求無(wú)法評(píng)估整個(gè)業(yè)務(wù)流程的真實(shí)用戶體驗(yàn)。
高手做法:使用Transaction Controller將一系列相關(guān)的請(qǐng)求(Sampler)組合成一個(gè)邏輯上的“事務(wù)”。JMeter會(huì)自動(dòng)統(tǒng)計(jì)這個(gè)事務(wù)整體的響應(yīng)時(shí)間、吞吐量、是否成功等關(guān)鍵指標(biāo),讓你能從業(yè)務(wù)視角而非技術(shù)視角評(píng)估性能。
使用方法:右鍵線程組->添加->邏輯控制器->Transaction Controller。
![]()
參數(shù)說(shuō)明:
Name:控制器名稱,可以根據(jù)實(shí)際情況進(jìn)行設(shè)置
Comments:注釋,描述在業(yè)務(wù)中的作用
Generate Parent Sample:選中,事務(wù)控制器將作為其他取樣器的父級(jí)取樣器進(jìn)行展示;不選,事務(wù)控制器僅作為獨(dú)立的取樣器進(jìn)行展示
Include duration of timer and pre-post processors in generated sample:是否在生成的取樣器中統(tǒng)計(jì)包括計(jì)時(shí)器、預(yù)處理以及后置處理的延遲時(shí)間。默認(rèn)是不勾選。
![]()
執(zhí)行后,可以發(fā)現(xiàn),勾選Generate Parent Sample 后,聚合報(bào)告會(huì)將事務(wù)控制器及其下的取樣器執(zhí)行情況均匯總統(tǒng)計(jì),最終僅以事務(wù)控制器作為結(jié)果進(jìn)行匯總統(tǒng)計(jì)。
![]()
5、常數(shù)吞吐量定時(shí)器- 精準(zhǔn)控制壓力的節(jié)流閥
新手做法:為了模擬一定壓力,盲目設(shè)置線程組的“線程數(shù)”和“循環(huán)次數(shù)”,或者使用固定的“思考時(shí)間”。結(jié)果要么壓力瞬間飆高導(dǎo)致服務(wù)器被打垮,要么壓力曲線呈鋸齒狀起伏不定,無(wú)法實(shí)現(xiàn)穩(wěn)定、精確的吞吐量控制,測(cè)試結(jié)果毫無(wú)參考價(jià)值。
高手做法:使用Constant Throughput Timer,以每分鐘采樣數(shù)為單位,精確地控制整個(gè)測(cè)試計(jì)劃每秒需要發(fā)出的請(qǐng)求數(shù)。這是實(shí)現(xiàn)穩(wěn)定壓力模型、進(jìn)行容量規(guī)劃和穩(wěn)定性測(cè)試的終極神器。
使用方法:在測(cè)試計(jì)劃、線程組或某個(gè)HTTP請(qǐng)求上右鍵 -> 添加 -> 定時(shí)器 -> Constant Throughput Timer。
情景設(shè)置:假設(shè)你需要評(píng)估一個(gè)下單接口的容量,業(yè)務(wù)上這個(gè)接口的峰值流量是 每分鐘處理1200個(gè)請(qǐng)求(即每秒20個(gè)請(qǐng)求)。
![]()
JMeter會(huì)自動(dòng)計(jì)算和調(diào)節(jié)!它會(huì)智能地控制每個(gè)線程的請(qǐng)求間隔,確保所有線程在一分鐘內(nèi)發(fā)出的請(qǐng)求總數(shù)精確地等于你設(shè)定的目標(biāo)值(1200次)。這樣你得到的壓力曲線將是一條平穩(wěn)的直線,而不是劇烈波動(dòng)的鋸齒線。
這意味著:
對(duì)服務(wù)器友好:你不會(huì)用突發(fā)流量沖垮服務(wù)器,從而得到更真實(shí)的性能數(shù)據(jù)。
結(jié)果可衡量:你可以清晰地看到,在穩(wěn)定的每秒20個(gè)請(qǐng)求的壓力下,系統(tǒng)的響應(yīng)時(shí)間、錯(cuò)誤率、資源消耗是多少。然后你可以逐步提高目標(biāo)吞吐量(如到1500、1800...),直到系統(tǒng)出現(xiàn)瓶頸(如響應(yīng)時(shí)間陡增或錯(cuò)誤率上升),這個(gè)拐點(diǎn)就是系統(tǒng)的最大容量。
模擬真實(shí)場(chǎng)景:線上業(yè)務(wù)流量通常是相對(duì)平穩(wěn)的,而非瞬間爆發(fā)的,這個(gè)定時(shí)器能最真實(shí)地模擬這一特性。
關(guān)鍵配置:
Target throughput (in samples per minute):目標(biāo)吞吐量。這是核心參數(shù),填寫(xiě)你希望達(dá)到的每分鐘請(qǐng)求數(shù)。
Calculate throughput based on:吞吐量計(jì)算基準(zhǔn)。
This thread only:僅控制當(dāng)前線程的吞吐量。
All active threads (推薦):基于所有活動(dòng)線程數(shù)來(lái)計(jì)算和控制總吞吐量。
All active threads in current thread group:基于當(dāng)前線程組的所有活動(dòng)線程來(lái)計(jì)算。
All active threads (shared):跨所有線程組控制(需要設(shè)置為全局定時(shí)器)。
6、If Controller (如果控制器)
- 讓腳本擁有智能判斷的能力
新手做法:為了模擬不同場(chǎng)景,編寫(xiě)多個(gè)獨(dú)立的測(cè)試腳本(如一個(gè)“成功登錄”的腳本,一個(gè)“登錄失敗”的腳本)。或者將所有請(qǐng)求線性執(zhí)行,無(wú)法根據(jù)服務(wù)器的響應(yīng)結(jié)果動(dòng)態(tài)決定后續(xù)流程,導(dǎo)致腳本僵硬、不真實(shí),且維護(hù)成本翻倍。
高手做法:使用If Controller,根據(jù)前一個(gè)請(qǐng)求的響應(yīng)結(jié)果、變量值或任何可評(píng)估的條件,智能地決定是否執(zhí)行其內(nèi)部的請(qǐng)求。這讓你的腳本能像真實(shí)用戶一樣“思考”,根據(jù)情況做出不同反應(yīng),極大增強(qiáng)了腳本的靈活性和真實(shí)性。
使用方法:右鍵線程組或控制器 -> 添加 -> 邏輯控制器 -> 如果(If)控制器。
![]()
比如上面定義了個(gè)變量,name=jmeter,下面有個(gè)百度的請(qǐng)求放在if控制器,if控制器條件里定義,當(dāng)name=jmeter成立時(shí),才會(huì)去執(zhí)行訪問(wèn)百度的請(qǐng)求,否則就不執(zhí)行。
![]()
參數(shù)說(shuō)明:
Name(名稱)
自定義控制器名稱,建議寫(xiě)清楚判斷邏輯,如:“僅當(dāng)?shù)卿洺晒r(shí)執(zhí)行”。
Condition(條件表達(dá)式)
核心參數(shù)!填寫(xiě)判斷條件,比如:"${status}" == "success"
Interpret Condition as Variable Expression?(將條件解釋為變量表達(dá)式?)
勾選:條件會(huì)被當(dāng)作“字符串表達(dá)式”解析(推薦)
不勾選:條件需返回 “true”或“false”字符串(老版本兼容用,不推薦)
Evaluate for all children?(為所有子節(jié)點(diǎn)評(píng)估條件?)
勾選:每個(gè)子節(jié)點(diǎn)執(zhí)行前都重新判斷條件(動(dòng)態(tài)場(chǎng)景用)
不勾選:只在控制器入口判斷一次(靜態(tài)條件用,性能略優(yōu))
另外,我還想到一個(gè)很常見(jiàn)的場(chǎng)景: 登錄失敗自動(dòng)重試(最多3次):
1、登錄請(qǐng)求 → 提取 ${login_status}
2、If Controller條件設(shè)置:
${login_status} != "OK" ,計(jì)數(shù)器+再次登錄請(qǐng)求,直到計(jì)數(shù)器大于3,才會(huì)停止重試,并結(jié)束后續(xù)的操作。
7、JSON提取器- 告別又臭又長(zhǎng)的正則表達(dá)式
新手做法:面對(duì)一個(gè)JSON格式的接口響應(yīng),依然使用復(fù)雜的正則表達(dá)式提取器,像解析HTML一樣用 "token":\s*"([^"]+)" 這種模式去匹配。一旦JSON格式稍有變化(比如多了一個(gè)空格),提取立刻失敗,調(diào)試到懷疑人生。
高手做法:
位置:在需要提取數(shù)據(jù)的HTTP請(qǐng)求上右鍵 -> 添加 -> 后置處理器 -> JSON提取器。
假如要提取的json為:
![]()
那我們應(yīng)該設(shè)置如下:
![]()
推薦原因:精準(zhǔn)而強(qiáng)大!使用標(biāo)準(zhǔn)的JSONPath語(yǔ)法,無(wú)論數(shù)據(jù)嵌套在多少層之下,都可以像打開(kāi)一個(gè)文件路徑一樣輕松定位。表達(dá)式直觀易讀,后期維護(hù)一看就懂,再也不用 decipher(破譯)那些天書(shū)般的正則表達(dá)式了。
配置說(shuō)明:
Names of created variables:定義變量名,用于存儲(chǔ)提取結(jié)果(例如Token)。
JSON Path expressions:填寫(xiě)JSONPath表達(dá)式來(lái)定位數(shù)據(jù)(例如 $.data.token)。
Match No.:可選。如果路徑匹配到多個(gè)值,用于選擇第幾個(gè)(0表示隨機(jī),1表示第一個(gè))。
Compute concatenation var:可選。如果匹配到多個(gè)值,將所有值拼接后存入變量(變量名_s)。
附:常用JSONPath語(yǔ)法示例
![]()
以上就是本次分享的JMeter核心“神器”。它們絕非冷門(mén)的功能,而是真正能讓你從“腳本的搬運(yùn)工”轉(zhuǎn)變?yōu)椤靶阅軠y(cè)試的設(shè)計(jì)師”的關(guān)鍵樞紐。
然而,工具的價(jià)值永遠(yuǎn)取決于使用它的人。我希望大家學(xué)到的不僅僅是這些元件的用法,更是一種思維模式的轉(zhuǎn)變:從“能用”到“好用”,從關(guān)注“單個(gè)請(qǐng)求”到關(guān)注“業(yè)務(wù)流”,從“手動(dòng)操作”到“自動(dòng)化與智能化”。
??轉(zhuǎn)崗軟件I測(cè)試/野路子技能提升
??想了解更多漲薪技能提升方法
??可以到我的個(gè)人號(hào):atstudy-js
即可加入領(lǐng)取 ??????
轉(zhuǎn)行、入門(mén)、提升、需要的各種干貨資料
內(nèi)含AI測(cè)試、 車載測(cè)試、AI大模型開(kāi)發(fā)、BI數(shù)據(jù)分析、銀行/游戲測(cè)試、AIGC
特別聲明:以上內(nèi)容(如有圖片或視頻亦包括在內(nèi))為自媒體平臺(tái)“網(wǎng)易號(hào)”用戶上傳并發(fā)布,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。
Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.