首页 > 代码库 > JMeter学习(十八)JMeter测试Java(二)

JMeter学习(十八)JMeter测试Java(二)

实例:

服务为:将输入的两个参数通过IO存入文件;

 

1、打开MyEclipse,编写Java代码
服务:
package test;import java.io.File;import java.io.PrintWriter;public class OutputService {    public static void output(String filename, int a, int b) throws Exception {        PrintWriter out = new PrintWriter(new File(filename));        out.write(a + ":" + b);        out.close();    }}

测试类:

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;//服务为:将输入的两个参数通过IO存入文件;public class PerformenceTest implements JavaSamplerClient {    private SampleResult results;    private String a;    private String b;    private String filename;    // 设置传入的参数,可以设置多个,已设置的参数会显示到Jmeter的参数列表中    public Arguments getDefaultParameters() {        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) {        results = new SampleResult();    }    // 测试执行的循环体,根据线程数和循环次数的不同可执行多次    public SampleResult runTest(JavaSamplerContext arg0) {        b = arg0.getParameter("b"); // 获取在Jmeter中设置的参数值        a = arg0.getParameter("a"); // 获取在Jmeter中设置的参数值        filename = arg0.getParameter("filename"); // 获取在Jmeter中设置的参数值        results.sampleStart();// jmeter 开始统计响应时间标记        try {            OutputService test = new OutputService();            test.output(filename, Integer.parseInt(a), Integer.parseInt(b));            results.setSuccessful(true);            // 被测对象调用        } catch (Throwable e) {            results.setSuccessful(false);            e.printStackTrace();        } finally {            results.sampleEnd();// jmeter 结束统计响应时间标记        }        return results;    }    // 结束方法,实际运行时每个线程仅执行一次,在测试方法运行结束后执行    public void teardownTest(JavaSamplerContext arg0) {    }    /*    public static void main(String[] args) {        // TODO Auto-generated method stub        Arguments params = new Arguments();        params.addArgument("a", "0");// 设置参数,并赋予默认值0        params.addArgument("b", "0");// 设置参数,并赋予默认值0        params.addArgument("filename","abc.txt");        JavaSamplerContext arg0 = new JavaSamplerContext(params);        PerformenceTest test = new PerformenceTest();        test.setupTest(arg0);        test.runTest(arg0);        test.teardownTest(arg0);    }    */}

生成jar包,放在JMeter_HOME/lib/ext目录下。

 

2、设置JMeter
以管理员身份打开JMeter,并创建Java Request后,结构如下图所示:
在Java请求中发现了自己新建的测试类:
 
我们在JMeter中发现参数有三个:
在这里我们使用到了两个函数:
(1)_Random生成随机整数;
(2)_RandomString生成随机字符串;
 
在线程组中设置并发线程数为5,保存后即可运行;
 
聚合报告:

结果成功,成功生成了5个文件:

 

3、遇到的问题

3.1 Export为Jar File导致Java Request的类名称无法找到;
3.2 JMeter java.lang.OutOfMemoryError: PermGen space问题:
  在JMeter.bat 中修改:
  set HEAP=-Xms512m -Xmx1024m
  set NEW=-XX:NewSize=128m -XX:MaxNewSize=128m
  set SURVIVOR=-XX:SurvivorRatio=8 -XX:TargetSurvivorRatio=50%
  set TENURING=-XX:MaxTenuringThreshold=2
  set RMIGC=-Dsun.rmi.dgc.client.gcInterval=600000 -Dsun.rmi.dgc.server.gcInterval=600000
  set PERM=-XX:PermSize=256m -XX:MaxPermSize=512m
3.3 JMeter需要以管理员身份打开,否则会出现:

JMeter学习(十八)JMeter测试Java(二)