1.打开Java编译器,新建一个项目"TestLength",然后新建一个包"app".
2.从Jmeter的安装目录lib\ext中拷贝两个文件"ApacheJMeter_core.jar" 和"ApacheJMeter_java.jar"到"Tester"的项目中,然后引入这两个JAR文件.(具体的引入方法参考各个Java编译器的使用方法)
3.在"app"包中新建一个类,名字叫"TestLength",不过这个类要继承"AbstractJavaSamplerClient"类,如果项目引入步骤二中的两个文件,就可以找到"AbstractJavaSamplerClient"类了.
4."TestLength"类在继承"AbstractJavaSamplerClient"类的同时也会继承四个方法,分别是"getDefaultParameters","setupTest","runTest"和"teardownTest"方法."getDefaultParameters"方法主要用于设置传入的参数;"setupTest"方法为初始化方法,用于初始化性能测试时的每个线程."runTest"方法为性能测试时的线程运行体;"teardownTest"方法为测试结束方法,用于结束性能测试中的每个线程.
5、把上面的例子打包,然后把生成的"TestLength。jar"文件拷贝到Jmeter的安装目录lib\ext下。
6、运行Jmeter,添加一个线程组,然后在该线程组下面添加一个Java请求(在Sampler中),在Java请求的类名称中选择咱们刚创建的类"app。TestLength",在下面参数列表的"testStr"后面输入要测试的字符串,然后添加一个监听器(聚合报告),设置一下模拟的用户数就可以测试了。如果测试不成功,Jmeter会在它自己个输出框中抛出这个字符串。
通过上面的例子我们可以发现,使用Jmeter自定义Java测试代码,配合Jmeter自带的函数,就可以实现出LoadRunner中"Java Vuser"协议的绝大多数功能。
附上代码:
package cn.gbase.jmeterTest; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.ResultSetMetaData; import java.sql.SQLException; import java.sql.Statement; import org.apache.jmeter.config.Arguments; import org.apache.jmeter.protocol.java.sampler.AbstractJavaSamplerClient; import org.apache.jmeter.protocol.java.sampler.JavaSamplerContext; import org.apache.jmeter.samplers.SampleResult; /** * * @author tianmao */ public class JmeterExtendJDBCTest extends AbstractJavaSamplerClient { private SampleResult results; private String arg1; /* Implements JavaSamplerClient.setupTest(JavaSamplerContext) */ public void setupTest(JavaSamplerContext arg0) { results = new SampleResult(); results.setSamplerData(toString()); results.setDataType("text"); results.setContentType("text/plain"); results.setDataEncoding("UTF-8"); results.setSuccessful(true); results.setResponseMessageOK(); results.setResponseCodeOK(); arg1 = arg0.getParameter("arg1", ""); if (arg1 != null && arg1.length() > 0) { results.setSamplerData(arg1); } } /* Implements JavaSamplerClient.teardownTest(JavaSamplerContext) */ public void teardownTest(JavaSamplerContext arg0) { System.out.println("treaddown"); } /* Implements JavaSamplerClient.getDefaultParameters() */ public Arguments getDefaultParameters() { Arguments params = new Arguments(); params.addArgument("arg1", "abc"); // 定义一个参数,显示到Jmeter的参数列表中,第一个参数为参数默认的显示名称,第二个参数为默认值 return params; } @Override public SampleResult runTest(JavaSamplerContext context) { int len = 0; results.sampleStart(); // 定义一个事务,表示这是事务的起始点,类似于LoadRunner的 // lr.start_transaction arg1 = context.getParameter("arg1"); doJDBCDeal(); results.sampleEnd(); // 定义一个事务,表示这是事务的结束点,类似于LoadRunner的 // lr.end_transaction return results; } public void doJDBCDeal() { try { Class.forName("com.gbase.jdbc.Driver"); } catch (ClassNotFoundException e) { e.printStackTrace(); } Connection conn = null; Statement stm = null; ResultSet rs = null; String sql = "select * from testView"; try { conn = DriverManager.getConnection("jdbc:gbase://192.168.1.11/kgdx?user=gbase&password=gbase20110531&connectTimeout=300000"); stm = conn.createStatement(); rs = stm.executeQuery(sql); results.setResponseCode("testStr:" + arg1); results.setResponseMessage("aaaaaaaaaaaaaaa"); results.setResponseCode("UTF-8"); results.setResponseCodeOK(); results.setResponseData(("execute:"+ sql+ "\r\n" + rs2Str(rs)).getBytes("utf-8")); } catch (Exception e) { results.setSamplerData(e.getMessage()); results.setSuccessful(false); // 用于设置运行结果的成功或失败,如果是"false"则表示结果失败,否则则表示成功 return; } finally { try { if (rs != null) rs.close(); } catch (SQLException e) { } try { if (stm != null) stm.close(); } catch (SQLException e) { } try { if (conn != null) conn.close(); } catch (SQLException e) { } } results.setSuccessful(true); } public String rs2Str(ResultSet rs) { StringBuilder sb = new StringBuilder(); try { ResultSetMetaData rsmd = rs.getMetaData(); int c = rsmd.getColumnCount(); while (rs.next()) { sb.append("----------------------------------------------------------").append("\r\n");; for (int i = 0; i < c; i++) { sb.append(rsmd.getColumnLabel(i + 1)).append("=").append(rs.getObject(i + 1)).append("\r\n"); } sb.append("\r\n"); } } catch (SQLException e) { e.printStackTrace(); } return sb.toString(); } }