大家都知道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檔案較多,要進行路徑引數化,把整個腳本內容放在一個事物控制器中,防止多執行緒下,獲取到不同的結果,運行設定相應多的執行緒處理就可以了,
相互學習,共同進步!
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/298107.html
標籤:java
