啸:呼啸;瀚:浩瀚。心胸要宽阔,犹如浩瀚的沙漠;沉默是金但是要记住,沉默是为了推翻一切,淹没时间的不公不正,像呼啸的暴风雨一样势不可挡。

《LoadRunner 没有告诉你的》之一——描述性统计与性能结果分析

上一篇 / 下一篇  2009-08-14 15:40:30 / 个人分类:性能测试

版权声明:本文可以被转载,但是在未经本人许可前,不得用于任何商业用途或其他以盈利为目的的用途。本人保留对本文的一切权利。如需转载,请在转载是保留此版权声明,并保证本文的完整性。也请转贴者理解创作的辛劳,尊重作者的劳动成果。

1C u GOqX0

作者:陈雷(Jackei)51Testing软件测试网4W Q3k&m H3B

邮箱:jackeichan@gmail.com

? _3~ BO0

Bloghttp://jackei.cnblogs.com

!Cf)a&vx*}1Ga0

 51Testing软件测试网*R,q7E oI.R4tn:z

z@+oi x+WQH0

LoadRunner中的90%响应时间是什么意思?这个值在进行性能分析时有什么作用?本文争取用最简洁的文字来解答这个问题,并引申出“描述性统计”方法在性能测试结果分析中的应用。51Testing软件测试网%DH aj oQ3Cl&{v
51Testing软件测试网N\*fu6tYo

 51Testing软件测试网TI3r-zJ+J

为什么要有90%用户响应时间?因为在评估一次测试的结果时,仅仅有平均事务响应时间是不够的。为什么这么说?你可以试着想想,是否平均事务响应时间满足了性能需求就表示系统的性能已经满足了绝大多数用户的要求?

nc(d#I9SC|'R3vq0

假如有两组测试结果,响应时间分别是{1351016}{56789},它们的平均值都是7,你认为哪次测试的结果更理想?

9L2ZHa!kwM-j!zFm0

假如有一次测试,总共有100个请求被响应,其中最小响应时间为0.02秒,最大响应时间为110秒,平均事务响应时间为4.7秒,你会不会想到最小和最大响应时间如此大的偏差是否会导致平均值本身并不可信?51Testing软件测试网W@ K)E)P7|)co

为了解答上面的疑问,我们先来看一张表:51Testing软件测试网%sdT {6M*{It8V
51Testing软件测试网.[#K9{,O5m

51Testing软件测试网 sHFk-o5o8g3x

F sp$c:bni o0

在上面这个表中包含了几个不同的列,其含义如下:

%f['d`lR0

CmdID  测试时被请求的页面

e.B`*Q ]%[0

NUM     响应成功的请求数量51Testing软件测试网 n s"dR^k"WH

MEAN   所有成功的请求的响应时间的平均值51Testing软件测试网 V)lPF%t{T^

STD DEV     标准差(这个值的作用将在下一篇文章中重点介绍)51Testing软件测试网({\Iqf x+HS t

MIN             响应时间的最小值

7EQ b%]*Y y0

50 th(60/70/80/90/95 th)        如果把响应时间从小到大顺序排序,那么50%的请求的响应时间在这个范围之内。后面的60/70/80/90/95 th也是同样的含义

R}c m?0

MAX     响应时间的最大值

9r X?T^dq2S:G"k0

我想看完了上面的这个表和各列的解释,不用多说大家也可以明白我的意思了。我把结论性的东西整理一下:

3hO/Lo,\0

1.     90%用户响应时间在LoadRunner中是可以设置的,你可以改为80%或95%;51Testing软件测试网D0T?DF9v$K

2.     对于这个表,LoadRunner中是没有直接提供的,你可以把LR中的原始数据导出到Excel中,并使用Excel中的PERCENTILE函数很简单的算出不同百分比用户请求的响应时间分布情况;51Testing软件测试网&W.n1?WtyX/P

3.     从上面的表中来看,对于Home Page来说,平均事务响应时间(MEAN)只同70%用户响应时间相一致。也就是说假如我们确定Home Page的响应时间应该在5秒内,那么从平均事务响应时间来看是满足的,但是实际上有10-20%的用户请求的响应时间是大于这个值的;对于Page 1也是一样,假如我们确定对于Page 1的请求应该在3秒内得到响应,虽然平均事务响应时间是满足要求的,但是实际上有20-30%的用户请求的响应时间是超过了我们的要求的;51Testing软件测试网vT5@$O9sU-B9Nb

4.     你可以在95 th之后继续添加96/ 97/ 98/ 99/ 99.9/ 99.99 th,并利用Excel的图表功能画一条曲线,来更加清晰表现出系统响应时间的分布情况。这时候你也许会发现,那个最大值的出现几率只不过是千分之一甚至万分之一,而且99%的用户请求的响应时间都是在性能需求所定义的范围之内的;

h.kD)L%DY4P.F6L(d0

5.     如果你想使用这种方法来评估系统的性能,一个推荐的做法是尽可能让你的测试场景运行的时间长一些,因为当你获得的测试数据越多,这个响应时间的分布曲线就越接近真实情况;51Testing软件测试网-M `-qi@VZ

6.     在确定性能需求时,你可以用平均事务响应时间来衡量系统的性能,也可以用90%或95%用户响应时间来作为度量标准,它们并不冲突。实际上,在定义某些系统的性能需求时,一定范围内的请求失败也是可以被接受的;

AdhDd.bL0

7.     上面提到的这些内容其实是与工具无关的,只要你可以得到原始的响应时间记录,无论是使用LoadRunner还是JMeter或者OpenSTA,你都可以用这些方法和思路来评估你的系统的性能。
|weT5jmaJT0

H#Ewl/D/t.[H0

 

(R^.h s%O GP_0

事实上,在性能测试领域中还有更多的东西是目前的商业测试工具或者开源测试工具都没有专门讲述的——换句话说,性能测试仅仅有工具是不够的。我们还需要更多其他领域的知识,例如数学和统计学,来帮助我们更好的分析性能数据,找到隐藏在那些数据之下的真相。51Testing软件测试网FFV8e#D[.t
51Testing软件测试网 rQ+Q%I7]yB


9@y Us7Xm4Iy Re0
 

-yiP_%ilH0

TAG:

feeling_6的个人空间 引用 删除 feeling_6   /   2009-08-14 17:02:23
你说的这些,我都是第一次听到
feeling_6的个人空间 引用 删除 feeling_6   /   2009-08-14 17:01:36
,谢谢
feeling_6的个人空间 引用 删除 feeling_6   /   2009-08-14 16:59:55
5
 

评分:0

我来说两句

Open Toolbar