前言
大家都知道Jmeter運行測試可以產生jtl文件,里邊包含了整個腳本的請求返回以及各種設置。近期遇到一個問題給大家分享下,就是作為性能測試組,從自動化測試組中拿到了一堆jtl文件,需要自己提取其中的請求報文。
用Jmeter打開jtl文件可以看到,請求報文是xml報文,顯示如下圖:
把jtl文件改為txt文件,打開看到如下圖:
內容還是比較多的,有N個請求,應該怎么提取呢,有Java基礎的朋友應該可以使用代碼直接提取,本人沒有去實現,應該難度不是很大。那對于測試比較熟悉的我們,怎么使用jmeter工具來提取呢?
我的思路是這樣的:
1.把原本的jtl文件只能在查看結果樹的請求中看到報文,轉變為使用BeanShell發送請求,可以在查看結果樹返回中看到所有的結果。
2.在查看結果樹中,已經可以看到響應了,返回的是全部的原jtl文件內容,提取其中的報文就可以使用正則表達式,邊界值提取器,得到自己想要的了,確定好請求的左右邊界,匹配數字寫-1,就是可以獲取全部符合要求的報文了。
簡單來講,就是把jtl文件后綴改為txt,在jmeter中使用beanshell取樣器中寫代碼,讀取文件,并把讀取結果放到Jmeter變量中,使用調試取樣器就可以看到結果。
3.這個時候獲取data數據,不能簡單使用${data}了,可以看做是綜合的結果,獲取時需要使用到ForEach控制器,因為多個jtl不能確定里邊有多少個請求需要提取,所以循環的結束字段${data_matchNr}。
4.最后一步,獲取變量并輸出,因為之前輸出時xml格式的報文進行了轉義,這邊做了一個還原,使用lang3包中的固定方法就可以實現,代碼如下:
最終輸出的txt文件,換行符隔開,可自行調整,然后用于性能測試腳本參數化,如下:
jtl文件較多,要進行路徑參數化,把整個腳本內容放在一個事物控制器中,防止多線程下,獲取到不同的結果,運行設置相應多的線程處理就可以了。
總結
到此這篇關于Jmeter如何獲取jtl文件中所有的請求報文的文章就介紹到這了,更多相關Jmeter獲取jtl中請求報文內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!
原文鏈接:https://blog.csdn.net/weixin_42561872/article/details/120127991