“未来的世界:方向比努力重要,能力比知识重要,健康比成绩重要,生活比文凭重要,情商比智商重要! ”    ——清华大学校长留给毕业生的一段话

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

上一篇 / 下一篇  2007-09-16 23:36:41 / 个人分类:LR

 

LoadRunner中的90%响应时间是什么意思?这个值在进行性能分析时有什么作用?本文争取用最简洁的文字来解答这个问题,并引申出“描述性统计”方法在性能测试结果分析中的应用。
5r$K"f L&C9aV:Xs0

2f3i6SA X0

 

9J n+|*b3t5aV'[a0

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

7w)zo-}P0

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

q!E#jCc.V0

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

为了解答上面的疑问,我们先来看一张表:
jT5`4lW X0

1U3^%E!Jt&U*Zt0

51Testing软件测试网`-r4e(c!aW_

51Testing软件测试网A8Q Rs)iv-w'kg"K:dy

在上面这个表中包含了几个不同的列,其含义如下:51Testing软件测试网%X,rp)y[3ZhR

CmdID  测试时被请求的页面51Testing软件测试网|5k5n z^ D(u

NUM     响应成功的请求数量

D$v(RASN Z,\0

MEAN   所有成功的请求的响应时间的平均值

/wG+p2E \0

STD DEV     标准差(这个值的作用将在下一篇文章中重点介绍)

U]c#y?o,o0

MIN             响应时间的最小值51Testing软件测试网K[/c!eRu

50 th(60/70/80/90/95 th)        如果把响应时间从小到大顺序排序,那么50%的请求的响应时间在这个范围之内。后面的60/70/80/90/95 th也是同样的含义51Testing软件测试网)`n+c~7f['H

MAX     响应时间的最大值51Testing软件测试网H4[ u H4s|Wq.u

我想看完了上面的这个表和各列的解释,不用多说大家也可以明白我的意思了。我把结论性的东西整理一下:51Testing软件测试网(c UpibN z

1.     90%用户响应时间在LoadRunner中是可以设置的,你可以改为80%或95%;

w-U j#bF%Wg3w d2Z0

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

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

!H3p#utk0

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

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

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

7.     上面提到的这些内容其实是与工具无关的,只要你可以得到原始的响应时间记录,无论是使用LoadRunner还是JMeter或者OpenSTA,你都可以用这些方法和思路来评估你的系统的性能。51Testing软件测试网t6u1w)MB5wEO l(p
51Testing软件测试网$J J3m+ST m(PB

 

7Lyu-l[pp3b0

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

欢迎各位同行高手灌水拍砖 ^_^
U!IA ^h0R{(o.r;n3d0

9v$}XX G!S0

TAG: LR

 

评分:0

我来说两句

我的栏目

日历

« 2024-04-21  
 123456
78910111213
14151617181920
21222324252627
282930    

数据统计

  • 访问量: 58052
  • 日志数: 103
  • 图片数: 4
  • 文件数: 2
  • 建立时间: 2007-05-20
  • 更新时间: 2010-11-23

RSS订阅

Open Toolbar