记一次性能测试中,因为自己设置问题,导致测试结果偏差

前言

这个性能测试真的感觉做了好久,一直都没有一个好的结果。

为什么要记录,因为想让自己以后不再犯类似错误!

要知道的几个知识点

你看完,肯定会感谢我的,建议收藏!

关于系统支持并发数计算:

1、使用系统用户数量*(5%~20%):

比如用户数为200人,平均取最大用户数为80用户左右,参考维基百科,可以自行查找

2、按照经典公式计算:

平均每天大约200人使用系统8小时,从登录到退出平均时间为4小时,那么

平均并发用户数为:C = 2004/8 = 100 并发用户数峰值为:C' = 100 + 3根号100 =130

参考自网络,感兴趣自己去查即可。

关于测试策略调整:

  • 连接及相应超时设置为3分钟
  • submitsave取样器之间间隔30秒
  • 取消设置KeepAlive

测试过程

因为测试结果一直很不理想,导致整体进度很慢,多方尝试,现把尝试方案及测试过程记录如下,以便他人参考和自己学习记录,尝试方案如下:

1、客户端设置keep-alive,默认连接、响应超时,单服务

得出结论:

经常出现数据库死锁、service not started,页面无法登陆

2、客户端设置keep-alive,默认连接、响应超时设置3分钟,单服务

经常出现数据库死锁、service not started,页面无法登陆

3、客户端取消设置keep-alive,默认连接、响应超时设置3分钟,submit与save取样器间隔1分钟,3服务

0报错,吞吐量6.1/sec,成功率100%。

4、客户端取消设置keep-alive,默认连接、响应超时设置3分钟,submit与save取样器间隔1分钟,单服务

0报错,吞吐量5.5/sec,成功率100%。

整个过程很曲折,好在遇到比较有耐心和超强的技术解决问题,也让我在这次测试中学习很多。

总结:

关于Keep-Alive设置对结果影响:

  1. 设置Keep-Alive可以避免连接建立和释放的开销,但Tcp连接容易导致系统资源无效占用,浪费系统资源。
  2. 去掉 KeepAlive可以模拟多用户访问时每次请求是从不同源端新建请求连接,能更有效模拟真实测试压力,适用于真实用户直接访问的服务接口和页面压测。
  3. 在HTTP 1.1版本后,默认开启Keep-Alive模式,可以加入 Connection: close才关闭连接,当然也可以设置Keep-Alive模式的属性,例如 Keep-Alive: timeout=5, max=100,表示这个TCP通道可以保持5秒,max=100,表示这个长连接最多接收100次请求就断开。(来自网络参考)
相关推荐
Apifox1 天前
Apifox 11 月更新|AI 生成测试用例能力持续升级、JSON Body 自动补全、支持为响应组件添加描述和 Header
前端·后端·测试
MegatronKing6 天前
一个有意思的问题引起了我的反思
前端·后端·测试
FIT2CLOUD飞致云7 天前
思维导图模式下测试用例支持使用富文本编辑器,MeterSphere开源持续测试工具v3.6.7 LTS版本发布
软件测试·测试用例·测试·metersphere
MegatronKing8 天前
Reqable 3.0版本云同步的实践过程
前端·后端·测试
艾莉丝努力练剑9 天前
【自动化测试实战篇】Web自动化测试实战:从用例编写到报告生成
前端·人工智能·爬虫·python·pycharm·自动化·测试
虎子_layor10 天前
告别JMeter!我用 k6 5 分钟完成高并发压测
后端·测试
Apifox15 天前
如何在 Apifox 中使用「模块」合理地组织接口
前端·后端·测试
货拉拉技术15 天前
货拉拉数据工厂:从3k+工具到AI智能体,我们如何让造数效率翻倍?
测试
孟陬15 天前
Bun Test 不支持时间快进?我用这招让单元测试提速 8 倍!
node.js·测试·bun
霍格沃兹_测试16 天前
软件测试 | 测试开发 | 专项测试技术初识Hook
测试