1. 程式人生 > 其它 >如何編寫符合jmeter規範的java指令碼

如何編寫符合jmeter規範的java指令碼

Jmeter的Sampler用來模擬向被測試系統發起請求的,Jmeter會記錄取樣的結果,也就是TPS、響應時間等效能指標。接下來就是使用Java請求進行一個介面測試。

大致流程:

1、匯入jar包:匯入Jmeter相關jar包

2、編寫指令碼:使用Eclipse或者IntelliJ IDEA,進行Java測試指令碼的編寫

3、匯出為jar包:使用Eclipse或者IntelliJ IDEA將測試指令碼編譯打包為jar包匯出

4、配置Jmeter:使用自編譯的jar包,以及一些相關配置進行效能測試

5、選擇自編寫jar包:自編譯jar包

6、Jmeter執行:開始執行

實戰操作

一、核心步驟(以我實際操作為例)

1.建立工程

使用IntelliJ IDEA建立一個Java工程,取名為JmeterTest;

2.新增依賴

2.1lib及子目錄依賴

a.使用Jmeter執行Java指令碼,需要用到Jmeter提供的框架jar包(分別在Jmeter目錄下的lib和ext目錄下)

ext:

ApacheJMeter_core.jar

ApacheJMeter_java.jar

lib:

slf4j-api-1.7.25.jar

jorphan.jar

Jmeter5.3需要多新增一個jar包:oro-2.0.8.jar

b.將JMeter的lib目錄下的jar檔案新增進此工程;

注意:此處有坑,不能只新增lib這個大目錄,還需要新增lib目錄下的ext和junit目錄,否則無法呼叫相關jar包

lib目錄下兩個兩個子目錄

2.2IDEA操作

1、開啟 File -> Project Structure (Ctrl + Shift + Alt + S)或者使用快捷鍵

3.指令碼編寫

建立一個類並實現JavaSamplerClient介面或繼承AbstractJavaSamplerClient,並重寫:

public Arguments getDefaultParameters():設定可用引數及的預設值;自定義的引數,它可以獲取到Jmeter面板上的引數

public void setupTest(JavaSamplerContext arg0):每個執行緒測試前執行一次,做一些初始化工作;

public SampleResult runTest(JavaSamplerContext arg0):開始測試,從arg0引數可以獲得引數值;執行業務程式碼函式,在setupTest方法後執行,每個執行緒執行N次

public void teardownTest(JavaSamplerContext arg0):測試結束時呼叫;

query:

package cn.testfan;

import java.sql.*;

public class queryTest {
public static void main(String[] args) throws ClassNotFoundException, SQLException {
// 1.註冊驅動
Class.forName("com.mysql.cj.jdbc.Driver");
String url = "jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8";
String userName = "root";
String password = "root";
String sql = "SELECT * FROM boys";
// 2.建立連結:通過ip、埠號、資料庫名、使用者名稱、密碼
Connection conn = DriverManager.getConnection(url,userName,password);
// 3.對SQL語句做預編譯,提升執行效能,返回一個經過變異後的SQL語句物件PreparedStatement
PreparedStatement ps = conn.prepareStatement(sql);
// 5.執行SQL
ResultSet set = ps.executeQuery();
while (set.next()){
String boyNum = set.getString("boyNum");
String matchNum = set.getString("matchNum");
System.out.println("boyNum為:" + boyNum);
System.out.println("matchNum為:" + matchNum);
System.out.println("++++++++++");
}
// 6.關閉資料庫連結
conn.close();
}
}

轉換為Jmeter可以執行的指令碼:
類名後新增implements JavaSamplerClient,點選ALT+Enter
update:
package cn.testfan;

import org.apache.jmeter.config.Arguments;
import org.apache.jmeter.protocol.java.sampler.JavaSamplerClient;
import org.apache.jmeter.protocol.java.sampler.JavaSamplerContext;
import org.apache.jmeter.samplers.SampleResult;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;

/*
自定義的測試類,實現了Jmeter的介面JavaSamplerClient
*/
public class InsertTest implements JavaSamplerClient {
// String url = "jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8";
// String userName = "root";
// String password = "root";
// String boyNum = "boy-001";
// String matchNum = "111";
String sql = "INSERT INTO boys (boyNum, matchNum) VALUES (?,?)";
PreparedStatement ps;
Connection conn;
public static void main(String[] args) {
// 模擬Jmeter執行一次指令碼
InsertTest test = new InsertTest();
JavaSamplerContext context = new JavaSamplerContext(test.getDefaultParameters());
test.setupTest(context);
test.runTest(context);
test.teardownTest(context);
}
/*
* 初始化函式,每個執行緒先執行此函式,並且僅執行一次
*/
@Override
public void setupTest(JavaSamplerContext javaSamplerContext) {
try {
// 1.註冊驅動
Class.forName("com.mysql.cj.jdbc.Driver");
// 2.建立連結:通過ip、埠號、資料庫名、使用者名稱、密碼
String dbUrl = javaSamplerContext.getParameter("dbUrl");
String dbUserName = javaSamplerContext.getParameter("dbUserName");
String dbPassWord = javaSamplerContext.getParameter("dbPassWord");
conn = DriverManager.getConnection(dbUrl,dbUserName,dbPassWord);
// 3.對SQL語句做預編譯,提升執行效能,返回一個經過變異後的SQL語句物件PreparedStatement
ps = conn.prepareStatement(sql);
} catch (ClassNotFoundException | SQLException e) {
e.printStackTrace();
}

}
/*
* 執行業務程式碼函式,在setupTest方法後執行,每個執行緒執行N次
*/
@Override
public SampleResult runTest(JavaSamplerContext javaSamplerContext) {
//給請求起個名字
SampleResult sampleResult = new SampleResult();
sampleResult.setSampleLabel("insert");
//請求開始
sampleResult.sampleStart();
try {
// 4、對SQL語句中的問號進行替換
String boyNum = javaSamplerContext.getParameter("boyNum");
String matchNum = javaSamplerContext.getParameter("matchNum");
// int age = javaSamplerContext.getIntParameter("age");
ps.setString(1,boyNum);
ps.setString(2,matchNum);
// 5.執行SQL
int rows = ps.executeUpdate();
if (rows == 1){
//請求成功
sampleResult.setSuccessful(true);
}else{
//請求失敗
sampleResult.setSuccessful(false);
}
String response = "插入的行數為:"+rows;
sampleResult.setResponseData(response,"utf-8");

System.out.println("插入的資料行數為:" + rows);
} catch (SQLException e) {
e.printStackTrace();
}
//請求結束
sampleResult.sampleEnd();
return sampleResult;
}

@Override
public void teardownTest(JavaSamplerContext javaSamplerContext) {
// 6.關閉資料庫連結
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
/*
* 自定義的引數,它可以獲取到Jmeter面板上的引數
*/
@Override
public Arguments getDefaultParameters() {
Arguments arguments = new Arguments();
arguments.addArgument("dbUrl","jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8");
arguments.addArgument("dbUserName","root");
arguments.addArgument("dbPassWord","root");
arguments.addArgument("boyNum","boy-007");
arguments.addArgument("matchNum","111");
return arguments;
}
}


3.1服務

package test;

import java.io.File;

import java.io.PrintWriter;

/**

* Created by April_Chou on 2018/4/10.

*/

public class OutputService {undefined

public static void output(String filename,int a, int b)throws Exception {undefined

PrintWriter out =new PrintWriter(new File(filename));

out.write(a+":"+b);

out.close();

}

}

3.2測試類:

package test;

import org.apache.jmeter.config.Arguments;

import org.apache.jmeter.protocol.java.sampler.JavaSamplerClient;

import org.apache.jmeter.protocol.java.sampler.JavaSamplerContext;

import org.apache.jmeter.samplers.SampleResult;

/**

* Created by April_Chou on 2018/4/10.

*/

public class PerformenceTestimplements JavaSamplerClient {undefined

private SampleResultresults;

private Stringa;

private Stringb;

private Stringfilename;

// 設定傳入的引數,可以設定多個,已設定的引數會顯示到Jmeter的引數列表中

public ArgumentsgetDefaultParameters() {undefined

Arguments params =new Arguments();

params.addArgument("filename", "0");//設定引數,並賦予預設值0

params.addArgument("a", "0");//設定引數,並賦予預設值0

params.addArgument("b", "0");//設定引數,並賦予預設值0

return params;

}

// 初始化方法,實際執行時每個執行緒僅執行一次,在測試方法執行前執行

public void setupTest(JavaSamplerContext arg0) {undefined

results =new SampleResult();

}

// 測試執行的迴圈體,根據執行緒數和迴圈次數的不同可執行多次

@Override

public SampleResultrunTest(JavaSamplerContext arg0) {undefined

b = arg0.getParameter("b"); // 獲取在Jmeter中設定的引數值

a = arg0.getParameter("a"); // 獲取在Jmeter中設定的引數值

filename = arg0.getParameter("filename"); // 獲取在Jmeter中設定的引數值

results.sampleStart();// jmeter 開始統計響應時間標記

try {undefined

OutputService test =new OutputService();

test.output(filename,Integer.parseInt(a), Integer.parseInt(b));

results.setSuccessful(true);

// 被測物件呼叫

}catch (Throwable e) {undefined

results.setSuccessful(false);

e.printStackTrace();

}finally {undefined

results.sampleEnd();// jmeter 結束統計響應時間標記

}

return results;

}

// 結束方法,實際執行時每個執行緒僅執行一次,在測試方法執行結束後執行

public void teardownTest(JavaSamplerContext arg0) {undefined

}

public static void main(String[] args) {undefined

// TODO Auto-generated method stub

Arguments params =new Arguments();

params.addArgument("a", "0");//設定引數,並賦予預設值0

params.addArgument("b", "0");//設定引數,並賦予預設值0

JavaSamplerContext arg0 =new JavaSamplerContext(params);

PerformenceTest test =new PerformenceTest();

test.setupTest(arg0);

test.runTest(arg0);

test.teardownTest(arg0);

}

}

4.Export為Runnable Jar File

開啟IDEA的file -> Project Structure或者快捷方式,進入專案配置頁面。如下圖:

Artifacts

點選Artifacts,進入Artifacts配置頁面,點選 + ,選擇如下圖的選項

說明:

第一步選擇Main函式執行的類,可以進行自動搜尋。

第二步選擇如圖的選項,目的是對第三方Jar包打包時做額外的配置,如果不做額外的配置可不選這個選項(但不保證打包成功)

第三步需要在測試類的目錄下,新建一個resources目錄,將MANIFEST.MF檔案儲存在這裡面,因為如果用預設預設值的話,在IDEA12版本下會有bug。

點選OK之後,出現如下圖介面,右鍵點選output root,點選Create Directory,建立一個libs,將所有的第三方JAR放進libs目錄下,成功之後,如下圖所示:

點選Build->Build Artifacts,選擇build

build

就會生成我們需要的jar包。其位置在專案目錄的out目錄下

jar包成功

5.Jmeter匯入

將此jar包放入JMETER_HOME\lib\ext目錄

6.開啟Jmeter

建議以管理員身份開啟JMeter

7.配置Jmeter

建立執行緒組、Java請求、圖形結果、檢視結果樹、聚合報告、用表格察看結果,進行測試

注意:

這樣的Java請求值需要你在相應的盤建立一個資料夾,否則會執行失敗,我這裡是D盤建立了一個test的資料夾。

介面

Java請求裡的引數可以使用函式助手進行填充,如下圖:

執行緒組設定

8.執行結果

原文連結:https://blog.csdn.net/weixin_42509720/article/details/114040784