如何編寫符合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