8c}q:m'C;g(u mz303244性能测试的目的是检查软件的平均响应时间或者吞吐量是否符合指定的标准。
*d eJ2J/lba'oce30324451Testing软件测试网|K X7Z4x7WGF)A|例如,当测试前已经获知在线人数为10000,可以设定性能测试的目的是检测软件典型交易的平均响应时间是否符合小于5秒的指标值。
)F:a0| Vh4u30324451Testing软件测试网2~#C0O&IM例如,当测试前不知道在线人数是多少,但是已经获知该软件在一定的时间周期内(t)必须处理N笔交易,可以设定性能测试的目的是检测软件典型交易的吞吐量是否符合大于25笔交易/秒的指标值。51Testing软件测试网 x(@ K@\a O|
!\%V0W0Rxz X/aZ[303244但是,在第二种情况出现时,还应该考虑若软件的吞吐量符合指定的指标值时,软件典型交易的平均响应时间是否符合小于5秒的指标值。
t*xUL,g0d30324451Testing软件测试网$`0UP sgc$T7h;G为什么呢?
F g(p/ow"io qr7t30324451Testing软件测试网G-Z;[Q0a_*oI我们可以利用“门”的概念来理解这里面的偏差!51Testing软件测试网R1@ EJNT
8~6i l"B;z2E3M;bT303244首先,我们假设如下的情况:51Testing软件测试网0zPN _CE)l6F6Q
- 共有5个人;
- 有1扇门;
- 一个人通过这扇门需要花费1秒的时间;
R+^w-bB*@#@:H303244此时,这扇门的吞吐量为1人/秒。5个人通过这扇门的平均响应时间为(1+2+3+4+5)/5=3秒。
9p}6| BS._303244'M%T[&@i L1a-yL7{303244如何才能提高人的通过效率呢?即,如何才能提高门的吞吐量呢?51Testing软件测试网 K%Fe/{8xQi%B
q%Yv}+JWxA303244有两种方法:51Testing软件测试网M/O3\0jU L ?
51Testing软件测试网g3vme4o`qz(1)减小通过门的时间;51Testing软件测试网~ CQPzZQ L
51Testing软件测试网.W}%PIB9hoXk(2)增加门的数量51Testing软件测试网 HC:P+Z-s @FEqe CB
51Testing软件测试网.h#Ch8@;dK;ku}8]W例如,
)?0omQKO"@30324451Testing软件测试网Y J7c%]Ypp(1)将一个人通过门的时间减小为0.5秒,门的吞吐量变成了2人/秒;51Testing软件测试网 P%c8|/aV2} {}6O1K
[C j9z p Nn w303244(2)增加一个门,门的吞吐量也变成了2人/秒
S `a@ T0P303244{R h4R r ](g"m0h4W%_303244结果是:51Testing软件测试网nC XhH5}&w
51Testing软件测试网&cH3B-C7A~v(1)5个人通过改善通过时间的门的平均响应时间为(0.5+1+1.5+2+2.5)/5=1.5秒;
"g xy+u1Y iG)~z v303244/}Y:V0GtK303244(2)5个人通过两扇门的平均响应时间为(1+1+2+2+3)/5=1.8秒51Testing软件测试网] p*^]!]/S+@f
FtX|e3qH303244此时,你可以发现,软件开发员改进软件处理并发交易请求的方法有两个,第一种是提高单个请求的处理速率,第二种是增加处理请求的线程的数量;或者是两种方法的组合。但是,不同方法的使用并不代表吞吐量得到了提高,而同时软件典型交易的平均响应时间也获得了相同值的改善。
&f{[7Rj.qLV6p M~30324451Testing软件测试网k/T:X`w-?yR因此,在性能测试以吞吐量为检测指标的时候,不光要评估吞吐量是否符合了性能指标的要求,同时也必须考虑响应时间是否符合性能指标的要求。51Testing软件测试网4d@#wguV&G-lR
4? T\k3\wB ^303244假设,在测试前,规定了吞吐量为大于25笔交易/秒,平均响应时间为小于5秒,在测试后,若实际吞吐量等于27笔交易/秒,不能仅凭这个27笔交易/秒就确定该软件的性能符合要求了,还要看平均响应时间是否符合要求。这时的平均响应时间可能大于5秒。
;P,q {lcoX,l4x303244%k`h0q,T:GkM$|;\303244而,如果测试前,规定了在线人数为10000,平均响应时间为小于5秒,在测试后,仅凭实际平均响应时间等于4秒就可以判断该软件的性能符合要求。