压力测试工具jmter入门教程

时间:2020-12-11 11:40:13

1jmeter的聚合报告具体含义

聚合报告下方的图是对上方的表的一个可视化,所以在这里我们主要解释每一个表项是什么意思。

Label:请求的名称,就是我们在进行测试的httprequest sampler的名称

#Samples:总共发给服务器的请求数量

Average:单个请求的平均响应时间,单位是毫秒

Median:50%的请求的响应时间

90%Line:90%的请求的响应时间

95%Line:95%的请求的响应时间

99%Line:99%的请求的响应时间

Min:最小的响应时间

Max:最大的响应时间

Error%:错误率=错误的请求的数量/请求的总数

Throughput: 吞吐量即表示每秒完成的请求数

KB/sec: 每秒从服务器端接收到的数据量

 压力测试工具jmter入门教程

 

 

2jmeter的界面基础介绍

1.Threads:这个组件主要用来控制Jmeter并发时产生线程的数量,在它的下一级菜单下只有一个组件(线程组),可以这么理解每个线程就是一个虚拟的用户。所有的其他类型组件必须是(线程组)节点的子节点。

2.配置单元:和Sample组件一起工作,主要用来配置Sample如何来发起请求访问服务器,这个东西的主要特点是可以把一些Sample的共同配置放在一个元素里面方便管理,配置单元是有作用域的。作用域和树的那个关系一样越是上级节点的作用域越大,越是接近叶子节点的

作用域就越小,可以复写上级作用域的配置。

3.定时器 : 这个主要是用来调节(线程组),控制线程每次运行测试逻辑(比如说:发出请求)的时间间隔。当然这个下面还有很多类型的定时器,他们主要功能就是调节时间间隔,但个个组件之间的策略有很大不同。

4.前置处理器 和 后置处理器类似一个HOOK,在测试执行之前和执行之后执行一些脚本的逻辑。该组件我还没有具体使用过,但大致功能就是这样,非重点组件。

5.Sample : 可能上图中没有出现Sample,需要在(ThreadGroup)上添加才可以

Sample表示客户端发送某种格式或者规范的请求到服务端,所以大家看到了各种各样的Sample,其中有两个Http 相关的。一般用HttpClient功能和效率将更强。

6.断言: 意思是指对于Sample完成了请求发送之后,判断一下返回的结果是否满足期望。

7.监听器 : 这个组件不同于平时在Web编程的那种监听器,他是伴随着Jemeter测试的运行而从中抓取运行期间的数据的一个组件,经常使用的是聚合报告组件,从里面可以统计到测试的TPS,响应时间等关键测试数据。

8线程数:最大测试时使用的线程数。

Ramp-Up Period : Jmeter达到指定最大线程数的时间。

循环次数 : 如果是Forever,线程组中的线程将不间断的连续测试系统,当然也可以设置每个线程测试的次数,当完成了规定次数后,该线程将自动退出线程组。

调度器 主要用来指定该测试的一些时间信息,比如从几点到几点运行测试,如果到了指定时间测试没有进行完成,测试也会被停止。

接着在线程组下面添加Sample组件,我们添加一个HTTP Request HTTPClient组件,

 

 压力测试工具jmter入门教程

 

 

 

4.自定义Sample或者协议完成测试

 问题:在某些场景下我们会发现Jmeter里面提供的各种Sample不能满足自己的需求,应为这个世界上的压力测试的逻辑本来就是千变万化的,所以这个时候我们如果自己实现一套测试逻辑,这个时候需要使用jmeter 的扩展性。下面我们通过一个简单的例子来看看如何开发这样的一个自定义Sample? 自定Sample的生命周期是怎样的?

 

package com.alibaba.stress.load;

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;

public class LifecycleJMeterSampleextends AbstractJavaSamplerClient {

@Override

public Arguments getDefaultParameters() {

System.out.println("Get Parameter name! [getDefaultParameters]");

return super.getDefaultParameters();

}

@Override

public void setupTest(JavaSamplerContext context) {

System.out.println("[setupTest]");

super.setupTest(context);

}

@Override

public void teardownTest(JavaSamplerContext context) {

System.out.println("[teardownTest]");

super.teardownTest(context);

}

@Override

public SampleResult runTest(JavaSamplerContext ctx) {

SampleResult result = new SampleResult();

result.sampleStart();

System.out.println("[runTest]");

result.setSuccessful(true);

result.sampleEnd();

return result;

}

}

[java] view plaincopy

package com.alibaba.stress.load;  

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;  

public class LifecycleJMeterSample extends AbstractJavaSamplerClient {  

      

      

      

      

    @Override  

    public Arguments getDefaultParameters() {  

        System.out.println("Get Parameter name! [getDefaultParameters]");  

        return super.getDefaultParameters();  

    }  

    @Override  

    public void setupTest(JavaSamplerContext context) {  

        System.out.println("[setupTest]");  

        super.setupTest(context);  

    }  

    @Override  

    public void teardownTest(JavaSamplerContext context) {  

        System.out.println("[teardownTest]");  

        super.teardownTest(context);  

    }  

    @Override  

    public SampleResult runTest(JavaSamplerContext ctx) {  

        SampleResult result = new SampleResult();  

        result.sampleStart();  

        System.out.println("[runTest]");  

        result.setSuccessful(true);  

        result.sampleEnd();  

        return result;  

    }  

}  

[java] view plain copy

package com.alibaba.stress.load;  

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;  

public class LifecycleJMeterSample extends AbstractJavaSamplerClient {  

      

      

      

      

    @Override  

    public Arguments getDefaultParameters() {  

        System.out.println("Get Parameter name! [getDefaultParameters]");  

        return super.getDefaultParameters();  

    }  

    @Override  

    public void setupTest(JavaSamplerContext context) {  

        System.out.println("[setupTest]");  

        super.setupTest(context);  

    }  

    @Override  

    public void teardownTest(JavaSamplerContext context) {  

        System.out.println("[teardownTest]");  

        super.teardownTest(context);  

    }  

    @Override  

    public SampleResult runTest(JavaSamplerContext ctx) {  

        SampleResult result = new SampleResult();  

        result.sampleStart();  

        System.out.println("[runTest]");  

        result.setSuccessful(true);  

        result.sampleEnd();  

        return result;  

    }  

}