今天看到一篇文章讲解VU、RPS、RT,中间有一个公式以下图并发
点击查看原文连接测试
并发数 = RPS * 响应时间 网站
因而我在本地作了几回实验,试图验证一下公式的准确性spa
实验网站 www.baidu.com线程
100线程,一次迭代,启动时间1s,线程组和聚合报告如图所示3d
从结果能够看出,100并发/s,一次迭代,平均响应时间是68msblog
若是根据上面公式来看的话token
RPS = 并发数/响应时间 = 100/0.068 ,大约是1470/Sget
可是咱们在线程组中能够看出,预置的RPS是 100/S定时器
差距有点大哦~~~想一想为何呢?
100线程,持续迭代,1s内启动线程,持续运行10s。线程组和聚合报告如图所示。
从聚合报告能够看出来,平均TPS= 1303。那么咱们可不能够就认定这个TPS=RPS呢?
简单计算一下就知道了。
图中能够看出咱们的单次响应时间是72ms,那么1秒内大约能迭代14次。100个线程下,一秒内大约能发送1400个请求。
所以咱们的RPS大约是1400/S
这样就能看出来,一秒内发送1400次请求,可是1s内只有1300个请求能响应完毕
咱们再反向验证一下并发数
并发数 = RPS*响应时间,1400* 0.072 等于100.8,和线程组里面设置的并发数几乎相同。
若是咱们用Throughput=RPS去反向验证
并发数 = RPS*响应时间,1303* 0.072 等于93,和线程组里面设置的并发数就有一些差距了。
此次咱们直接加上RPS定时器,经过精准的RPS来验证公式
咱们让200RPS保持1分钟,查看聚合报告
首先咱们就能看出,在200RPS下,平均TPS只有172!
其次,平均并发数 = 200*0.047 = 9.4 意味着我只须要9个线程,就能够在一秒内释放200RPS的压力
能够算出每一个线程每秒的请求数是 200/9.4 =21,也就是一个线程一秒内最大迭代21次
反推每一个请求的响应时间 大约 是 1000/21 大约是 47ms
这一次咱们直接在线程组中设置刚刚20RPS下得出的平均并发数值 9,反向推断出RPS的准确性
计算一下RPS = 9 /0.043 约等于209
由于线程组只能设置整数,因此会和实验三有一些偏差,不影响测试的准确性
结尾语:从几回实验结果来看,在样本充足的状况下,公式是没有问题的。重点是作测试要时刻保持一颗质疑的心,不盲信任何权威 !