Jmeter如何獲取jtl文件中所有的請(qǐng)求報(bào)文詳解
前言
大家都知道Jmeter運(yùn)行測(cè)試可以產(chǎn)生jtl文件,里邊包含了整個(gè)腳本的請(qǐng)求返回以及各種設(shè)置。近期遇到一個(gè)問題給大家分享下,就是作為性能測(cè)試組,從自動(dòng)化測(cè)試組中拿到了一堆jtl文件,需要自己提取其中的請(qǐng)求報(bào)文。
用Jmeter打開jtl文件可以看到,請(qǐng)求報(bào)文是xml報(bào)文,顯示如下圖:
把jtl文件改為txt文件,打開看到如下圖:
內(nèi)容還是比較多的,有N個(gè)請(qǐng)求,應(yīng)該怎么提取呢,有Java基礎(chǔ)的朋友應(yīng)該可以使用代碼直接提取,本人沒有去實(shí)現(xiàn),應(yīng)該難度不是很大。那對(duì)于測(cè)試比較熟悉的我們,怎么使用jmeter工具來提取呢?
我的思路是這樣的:
1.把原本的jtl文件只能在查看結(jié)果樹的請(qǐng)求中看到報(bào)文,轉(zhuǎn)變?yōu)槭褂肂eanShell發(fā)送請(qǐng)求,可以在查看結(jié)果樹返回中看到所有的結(jié)果。
2.在查看結(jié)果樹中,已經(jīng)可以看到響應(yīng)了,返回的是全部的原jtl文件內(nèi)容,提取其中的報(bào)文就可以使用正則表達(dá)式,邊界值提取器,得到自己想要的了,確定好請(qǐng)求的左右邊界,匹配數(shù)字寫-1,就是可以獲取全部符合要求的報(bào)文了。
簡(jiǎn)單來講,就是把jtl文件后綴改為txt,在jmeter中使用beanshell取樣器中寫代碼,讀取文件,并把讀取結(jié)果放到Jmeter變量中,使用調(diào)試取樣器就可以看到結(jié)果。
3.這個(gè)時(shí)候獲取data數(shù)據(jù),不能簡(jiǎn)單使用${data}了,可以看做是綜合的結(jié)果,獲取時(shí)需要使用到ForEach控制器,因?yàn)槎鄠€(gè)jtl不能確定里邊有多少個(gè)請(qǐng)求需要提取,所以循環(huán)的結(jié)束字段${data_matchNr}。
4.最后一步,獲取變量并輸出,因?yàn)橹拜敵鰰r(shí)xml格式的報(bào)文進(jìn)行了轉(zhuǎn)義,這邊做了一個(gè)還原,使用lang3包中的固定方法就可以實(shí)現(xiàn),代碼如下:
最終輸出的txt文件,換行符隔開,可自行調(diào)整,然后用于性能測(cè)試腳本參數(shù)化,如下:
jtl文件較多,要進(jìn)行路徑參數(shù)化,把整個(gè)腳本內(nèi)容放在一個(gè)事物控制器中,防止多線程下,獲取到不同的結(jié)果,運(yùn)行設(shè)置相應(yīng)多的線程處理就可以了。
總結(jié)
到此這篇關(guān)于Jmeter如何獲取jtl文件中所有的請(qǐng)求報(bào)文的文章就介紹到這了,更多相關(guān)Jmeter獲取jtl中請(qǐng)求報(bào)文內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot任務(wù)調(diào)度器的實(shí)現(xiàn)代碼
SpringBoot自帶了任務(wù)調(diào)度器,通過注解的方式使用。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-12-12SpringBoot下Mybatis的緩存的實(shí)現(xiàn)步驟
這篇文章主要介紹了SpringBoot下Mybatis的緩存的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04SpringBoot實(shí)現(xiàn)讀取YML,yaml,properties文件
yml,yaml,properties三種文件都是用來存放配置的文件,一些靜態(tài)數(shù)據(jù),配置的數(shù)據(jù)都會(huì)存放到里邊。本文主要為大家整理了SpringBoot實(shí)現(xiàn)讀取YML,yaml,properties文件的方法,需要的可以參考一下2023-04-04