您的位置:首页 > 其它

性能测试工具之JMeter

2017-01-12 16:52 155 查看
http://mp.weixin.qq.com/s/Ued7V0IJSXAhBfLQZnFOxw

JMeter是Apache组织的开放源代码项目,它是功能和性能测试的工具,100%的用java实现,我们今天要用到的就是JMeter的性能测试部分。

首先我们先了解下压力测试的基本概念:

1  
吞吐率(Requests per second)概念:服务器并发处理能力的量化描述,单位是reqs/s,指的是某个并发用户数下单位时间内处理的请求数。某个并发用户数下单位时间内能处理的最大请求数,称之为最大吞吐率。计算公式:总请求数
/ 处理完成这些请求数所花费的时间,即
     
   Requestper second = Complete requests / Time taken for tests
2  
并发连接数(The number of concurrent connections)概念:某个时刻服务器所接受的请求数目,简单的讲,就是一个会话。
3  
并发用户数(The number of concurrent users,ConcurrencyLevel)概念:要注意区分这个概念和并发连接数之间的区别,一个用户可能同时会产生多个会话,也即连接数。
4  
用户平均请求等待时间(Time per request)计算公式:处理完成所有请求数所花费的时间/
(总请求数 /
并发用户数),即Time per request= Time taken for tests /( Completerequests / Concurrency
Level)
5 服务器平均请求等待时间(Time per request: across all concurrent requests)

计算公式:处理完成所有请求数所花费的时间 /
总请求数,即Time takenfor / testsComplete requests可以看到,它是吞吐率的倒数。同时,它也=用户平均请求等待时间/并发用户数,即
Time per request / Concurrency Level
下面我们来看看如何使用JMeter:

1 Jmeter 基本界面和组件的概念:






现在看到了Jmeter的主界面。下面介绍Jmeter中主要组件的功能和作用,
首先我们看看Jmeter在概念上的组件分类如图

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

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

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

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

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

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

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

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

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

操作实例:

         首先在TestPlan下面添加一个ThreadGroup组件,设置线程组组件各项参数

关键参数解释:

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

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

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

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

 

接着在线程组下面添加Sample组件,我们添加一个HTTPRequest HTTPClient组件,设置属性如下图:



最后添加监听器组件:Aggregate Report,大功告成!

运行:



好了,一个简单的压力测试例子完成了。大家可以从report中间看到一些性能结果的参数了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: