Jmeter參數化設置的5種方法


一. 用Jmeter中的函數獲取參數值,__Random,__threadNum,__CSVRead,__StringFromFile,具體調用方法如下:

${__Random(,,)},$,${__CSVRead(,)},${__StringFromFile(,,,)}。

參看Jmeter函數的使用,通過菜單“選項”->“函數助手對話框”,即可在“函數助手”彈出框上找到Jmeter的函數。

其中${__Random(,,)}方法的第一個參數為隨機數的下限,第二個參數為隨機數的上限,第三個參數為儲存隨機數的變量名;${__CSVRead(,)}方法中第一個參數是文件名,第二個參數是文件中的列(列數從0開始);${__StringFromFile(,,,)}方法中第一個參數是文件名,${__StringFromFile(,,,)}方法中沒有指定讀取文件中的哪一列的參數,所以${__StringFromFile(,,,)}只能讀取包含一列的文件。

 

二.用戶定義的變量

2.1 添加“配置元件”->“用戶定義的變量”

2.2 “名稱”中輸入變量名稱,此處以登錄為例,定義兩個變量username和password。“值”中可以直接輸入值,也可以通過Jmeter的函數__CSVRead,__StringFromFile從csv或dat文件中讀取,還可以通過前綴加隨機數的方法設置參數。

當參數值是某個前綴加一個數字時,可以用前綴名加${__Random(,,)}或$的方法設置參數值。如進行登錄測試之前,先准備了用戶名為perf_0到perf_1000的用戶,那么用戶名就可以設為perf_{__Random(0,1000,)}。

當參數值沒有規律的且量不太大時,可以通過${__CSVRead(,)},${__StringFromFile(,,,)}從文件中讀取,如將用戶名和密碼保存在user.csv文件中,user.csv的內容如下:

oriana,123456

admin,admin

dandan,123456

因為user.csv文件中有兩列數據,所以只能用${__CSVRead(,)}函數,username參數后的值設為${__CSVRead(user.csv,0)},password參數后的值設為${__CSVRead(user.csv,1)}。

三. 從csv文件中讀取(用Csv Data配置元件來進行參數化)

當參數的值沒有規律且量不太大時,可以用這種方法。

具體做法如下:

1、打開jmeter圖形界面工具,打開之前的腳本。

2、右鍵【添加】-【配置元件】-【Csv Data Set Config】

3、這個配置元件可以允許從你輸入的路徑來讀取文件,然后根據分隔符獲取到數據。

4、如下圖,輸入的數據。

講解:

a,名稱和注釋不需要過多解釋,自己定義。

b,Filename:參數化文件的讀取位置。這個路徑可以是絕對路徑也是可以相對路徑。在分布式測試中,還是利用相對路徑比較方便,因為有的機器可能安裝路徑不一樣。

c,File Encoding:編碼格式,選擇utf-8

d,Variable Names:變量名稱。這里定義的變量名稱,后面就可以直接用來引用了。(多個變量名稱以逗號隔開。例如username,passwd。參數化文件中同樣有對應的兩列數據。)

e,Ignore first line:忽略第一行數據。(類似loadrunner中第一行數據是變量名稱,如果你的配置文件中為了記憶第一行也是變量名,可以選擇是忽略這行數據)

f,Delimiter:分隔符,默認逗號。

g,Allow quoted data:是非選項,是否允許變量中間有分隔符,這里最好先默認false,數據中間最好不要有分隔符。

h,Recycle on EOF和Stop thread on EOF按需設置。是否循環,到結尾是否停止測試。我這里設置了True和False

i,Sharing mode:先選擇所有的線程都可以利用此參數化。

5、准備測試數據。這里只是簡單的寫了幾個數據來演示效果。

6、在請求中引用該變量。

引用方法是 ${}   ;其中{}內寫入參數化中的變量。

注:在parameter中加入一些多余的參數沒有問題,故在訪問百度的請求后面隨意加了一個參數。

7、修改循環次數。這里設置6次,是因為參數里面有5個數據,測試一下數據取完之后的效果。

8、點擊運行,查看結果樹。

可以看到共發送了6次請求,而且請求參數中已經獲取了變量的數據。

9、打開第二個請求。可以看到第二個請求的參數里面變量值為data-b。

順序讀取的。

10、找到最后一個請求,點開查看。

請求參數中searchid是data-a,說明數據是從頭開始取的,也就是數據是遍歷后循環的。

參數化完成了。

四.從數據庫中獲取

當參數的值沒有規律且量比較大時,可以選用這種方法。

具體做法如下:

4.1 下載MySQL JDBC “http://dev.mysql.com/get/Downloads/Connector-J/mysql-connector-java-5.1.12.zip/from/http://ftp.jaist.ac.jp/pub/mysql/”

4.2 解壓下載的zip包后,將其中的mysql-connector-java-5.1.12-bin.jar放到Jmeter的lib目錄下

4.3 添加“配置元件”->“JDBC Connection Configuration”,設置下列參數:

Database URL:jdbc:mysql://host:port/db(如jdbc:mysql://localhost:3306/testlink

JDBC Driver class:com.mysql.jdbc.Driver

username:連接數據庫的用戶名(如root)

password:連接數據庫的密碼

4.4 添加“Sampler”->“JDBC Request”,在SQL Query中輸入查詢語句,如下:

SELECT CONCAT (“[",

GROUP_CONCAT(

CONCAT("{username:'",login,"'"),

CONCAT("{password:'",password),"'}"),"]“) AS json FROM users

4.5 在4.4中的JDBC請求中添加“后置處理器”->“正則表達式提取器”,以提取3.4中的用戶名和密碼為例設置正則表達式提取器的參數:

引用名稱:user

正則表達式:username:’(.+?)’\{password:’(.+?)’

模板:$1$$2$

使用時,user_g1即為用戶名,user_g2即為對應用戶名的密碼;更多正則表達式提取方法參見Jmeter正則表達式提取器

五.用正則表達式從前面請求的響應數據中提取,具體操作見Jmeter正則表達式提取器

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM