JMeter线程组

Jmeter脚本的第一个要素是线程组(Thread Group),线程组需要设置以下参数:  
  ·线程数量。  
  ·ramp-up period。  
  ·循环次数。  
  ·启动时间:立即或者预定的时间,如果是后者,线程组所包含的元素也要指定这个起止时间。 

 

每个线程均独立运行测试计划。因此,线程组常用来模拟并发用户访问。如果客户机没有足够的能力来模拟较重的负载,可以使用jmeter的分布式测试功能来通过一个jmeter控制台来远程控制多个jmeter引擎完成测试。 

参数 ramp-up period 用于告知JMeter 要在多长时间内建立全部的线程。默认值是0。如果未指定ramp-up period ,也就是说ramp-up period 为零, JMeter 将立即建立所有线程,假设ramp-up period 设置成T 秒, 全部线程数设置成N个, JMeter 将每隔T/N秒建立一个线程。  
 
  线程组的大部分参数是不言自明的,只有ramp-up period有些难以理解, 因为如何设置适当的值并不容易。 首先,如果要使用大量线程的话,ramp-up period 一般不要设置成零。 因为如果设置成零,Jmeter将会在测试的开始就建立全部线程并立即发送访问请求, 这样一来就很容易使服务器饱和,更重要的是会隐性地增加了负载,这就意味着服务器将可能过载,不是因为平均访问率高而是因为所有线程的第一次并发访问而引起的不正常的初始访问峰值,可以通过Jmeter的聚合报告监听器看到这种现象。  
这种异常不是我们需要的,因此,确定一个合理的ramp-up period 的规则就是让初始点击率接近平均点击率。当然,也许需要运行一些测试来确定合理访问量。  
 
  基于同样的原因,过大的ramp-up period也是不恰当的,因为将会降低访问峰值的负载,换句话说,在一些线程还未启动时,初期启动的部分线程可能已经结束了。  
 

那么,如何检验ramp-up period太小了或者太大了呢?首先,推测一下平均点击率并用总线程除点击率来计算初始的ramp-up period。 例如,假设线程数为100, 估计的点击率为每秒10次, 那么估计的理想ramp-up period就是100/10=10秒。 那么,应怎样来提出一个合理的估算点击率呢?没有什么好办法,必须通过运行一次测试脚本来获得。 
 
  其次, 在测试计划(test plan)中增加一个聚合报告监听器,如下图所示,其中包含了所有独立的访问请求(一个samplers)的平均点击率。 第一次取样的点击率(如http请求)与ramp-up period 和线程数量密切相关。通过调整ramp-up period可以使首次取样的点击率接近平均取样的点击率。 

Ede Erm Options yelp 
Test man 
path 
-g SimpE 
Graph 
A Re Sins 
V" Ræuts 
Spine 
Aggregate Report 
Name: ggregate Reøod 
Wrie A" DMatoa 
URL 
Oet index page 
Select Language 
create 
TOTAL 
Average 
1343 
4327 
5451 
drowse„. 
2063 
D Log Errors Onw 
Ocunt 
Error% 
5999 0.00% 
82011000% 
8201010% 
Rate 
3Cdset

 
第三, 查验一下Jmeter日志(文件位置:JMeter_Home_Directory/bin) 的最后一个线程开始时第一个线程是否真正结束了,二者的时间差是否正常。 
 
总之,是否能确定一个适当的ramp-up time 取决于以下两条规则:  
 ·第一个取样器的点击率(hit rate)是否接近其他取样器的平均值,从而能否避免ramp-up period 过小。 
 ·在最后一个线程启动时,第一个线程是否在真正结束了,最好二者的时间要尽可能的长,以避免ramp-up period过大。 
 
有时,这两条规则的结论会互相冲突。这就意味着无法找到同时满足两条规则的合适的ramp-up period。糟糕的测试计划通常会导致这些问题,这是因为在这样的测试计划里,取样器将不能充分地采集数据,可能因为测试计划执行时间太短并且线程会很快的运行结束。 

posted @ 2017-11-28 12:33  春田花花同学会  阅读(93)  评论(0编辑  收藏  举报