为什么要在性能测试中设置思考时间?

上一篇 / 下一篇  2008-02-14 16:25:08

考虑时间Thinking Time指的是在性能测试脚本中,事务与事务之间,会有一些短暂的停顿,就好像真实用户在操作时,两次操作之间需要考虑一下。比如用户注册的时候,在打开注册页面到提交注册页面之间,是有一段考虑时间的(用户在填写个人信息)。
\s_m-~ E:C'sW!V X6r0 51Testing软件测试网p(m*SPP$v{GT7v
        下面就讨论一下在性能测试实战中,为什么要设置考虑时间。51Testing软件测试网&O/V0j4F.U/p1i_(G:b
 51Testing软件测试网)jx#^z X W
        先说一个概念:吞吐量,这指的是服务器系统(包括软件和硬件)单位时间内处理业务的数量。我们现在做一个小试验,写一个小程序,执行一个简单的业务,并且在程序中进行计时,计算每分钟能执行多少次。然后当我们运行1路这个程序的时候,每分钟能完成约6万次。好,现在问一个问题,如果我们起2路,是不是每一路都能达到 6万/分钟 的吞吐量?51Testing软件测试网 X6DN uF2ozq&g
 
!g i T1^y0        试验发现,当运行2路的时候,两个程序的数值都降了下来,但是它们的总和仍然是6万次。而且不管我们起多少路,这些程序的性能总和都接近于6万。
eZ-SQS'X&o l0 
&?o @9CO-T;gC0        这就好像一个人1分钟最快能吃1个馒头,你让他一个一个吃,他两分钟能吃2个,如果你让他一手拿一个,同时吃,他两分钟吃不了4个,还是只能吃两个。51Testing软件测试网SeAq `ZF/L
 
c7Eq(m&ou0        我们不是在说“考虑时间”么,哈哈,别急,因为上面的问题必须要先说清楚。51Testing软件测试网_j/y8[#S2yG3`
 
:rQ)c0mN4t'FS m]0        如果我们需要进行性能测试的业务是一个单纯的业务,就好像上面举的那个例子一样,那么测试脚本中就不需要设置“考虑时间”,因为不管你用什么方法测试,一个服务系统处理单一业务的吞吐量总是一个定值。
Zu ^x-W0 51Testing软件测试网7|@z)W)pmOTv,_
        但是在实际环境里面,往往一个系统都是要处理多种业务,并且这些业务之间是有逻辑关系的。举例说明,比如一个论坛系统,每天最常处理的业务有两个:A打开帖子、B回复帖子。那么每天系统处理AB业务的总数是不是一样的呢,答案很明显,看帖子多,回复的少一些。假设A:B=2:1。51Testing软件测试网.|7t$] [e8Sc1A
 51Testing软件测试网 v M)S u1Z[
        好,如果我们不设置考虑时间,起2路A的脚本,1路B的脚本进行性能测试,我们会得到什么结果呢?我们会得到这两个业务的吞吐量,并且能算出每个小时系统完成A、B业务的总数,吞吐量 × 时间 = 总数。51Testing软件测试网4lH'^6wy
 
:F7e-N/sI hqd0        这时我们发现,同样时间,AB业务的处理总数却不是2:1的关系,这是为什么呢?原因是这样的,我们在跑AB脚本的时候,这两组脚本都在尽全力争夺服务器的资源,他们的并发路数虽然是2:1,但是给服务器的压力却不一定是2:1,可能会出现偏差,测试结果就是最好的证据。A查看帖子由于响应时间短,因此跑的次数更多,最后的比例可能是4:1。
6f-Pl3k9wR4~F-F:|:i0 
[ y0k#[7W `0        那么这样的结果有什么问题呢。总结为一句话:测试环境的业务和真实环境不符,这样测出的数据没有价值。即使测试通过,也不能证明真实环境是ok的;或者即使测试不通过,也不能说明真实环境不ok,呵呵。
O$c)o9[!{`0 51Testing软件测试网`:@7C |e(lzB*A
        比如上面的例子,如果我们测出的结果是B回复帖子的吞吐量不够,响应时间太长,那可能是因为A业务抢走了过多的,本不属于A的资源,而引起了B的性能降低。51Testing软件测试网5a]y%h;O!wL"Ys
 
+Ka3v#sZ0T,@w0        说到这里,大家应该明白了,我们设置考虑时间,是为了保证测试复合业务的时候,各个业务之间的比例关系符合我们的真实生产环境。51Testing软件测试网'q1Ai$c){+@8c

;z:rNPqb0

TAG:

晓蕾,you  forerver lucky! 引用 删除 晓蕾LUCKY   /   2008-11-24 15:09:42
拜读了,写的很形象~
 

评分:0

我来说两句

日历

« 2024-05-12  
   1234
567891011
12131415161718
19202122232425
262728293031 

数据统计

  • 访问量: 10473
  • 日志数: 25
  • 建立时间: 2007-06-10
  • 更新时间: 2008-07-04

RSS订阅

Open Toolbar