WEB性能测试-并发测试

今天根据程序开发的逻辑和习惯来解决几个问题:

(1)JMeter并发测试的基本使用。

(2)redis和mysql相比的性能差距如何?

(3)大量的并发和请求下redis、mysql、nginx各自会出现的问题?

(4)遇到并发带来各种各样的问题如何解决?

问题一:JMeter并发测试的基本使用

(1)设置系统语言:Options->Choose Lanuage 里选择适合你的语言。

(2)添加线程组:

(3)设置线程属性:

线程数:也就是并发数。

Ramp-Up时间(秒):并发时间,0为同时并发。

循环次数:重复次数。

(4)添加HTTP请求:

协议:http或https。

服务器名称或IP:请求地址。

路径:要请求的路由或文件路径。

参数:添加请求参数。

(5)添加察看结果树:可查看发送的数据,返回的结果等。

(6)添加汇总报告:可查看错误率,吞吐量等。

问题二:大量的并发和请求下redis、mysql、nginx各自会出现的问题?

在同时并发2000的情况下(因为redis队列为异步,所以这里不考虑redis出列的性能问题):

mysql:错误率87.9%,成功条数241。

redis:错误率0.35%,成功条数1993。

总结:从以上结果可以看出在高并发场景下msyql扛不住压力错误率高。

结论:redis在处理并发性能优于mysql。

问题三:大量的并发和请求下redis、mysql、nginx各自会出现的问题?

3000并发循环请求3次相当于9000的次请求的情况下:

(1)nginx报错:Too many open files(打开的文件数超过限制nginx默认为1024)。

(2)redis报错:RDB: 2 MB of memory used by copy-on-write。

(3)mysql直接写入失败。

问题四:遇到并发带来各种各样的问题如何解决?

(1)nginx错误分析:最大打开文件数超过限制

python 复制代码
# 查看系统打开文件值 Max open files

  cat /proc/`ps -ef | grep nginx|grep -v grep|head -1|awk '{print $2}'`/limits

  # 修改

  vi /etc/systemd/ststem.conf

  # 修改两个值

  DefaultLimitNOFILE = 102400

  DefaultLimitNPROC = 102400

  # 随后重启系统

(2)redis错误分析:保存频繁导致内存不够了。(暂未找到最合适的方案)

点击查看更详细的错误分析:Redis-redis异常解决以及日常命令

(3)mysql暂没找到方案。

总结:

相同的配置&高并发场景下redis比mysql要可靠很多,伴随着并发越来越高服务器、程序、数据库各方面的问题扑面而来,不要慌,这才是你真正需要学习的东西!生于忧患死于安乐,只有不断的处理问题,才能真正的驾驭程序!祝你早日成功!!!

本文最高测试并发在3000循环次数为3次,服务器环境为lnmrp,系统配置为2核4G6M,因为redis的问题没有解决不能做更高的并发测试。并且还有一个redis的问题没有解决,待我研究几日说。

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:【文末自行领取】

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

相关推荐
愚昧之山绝望之谷开悟之坡7 分钟前
什么是uv和传统的区别
前端·chrome·uv
SRC_BLUE_1716 分钟前
NSSCTF - Web | 【第五空间 2021】pklovecloud
android·前端
golang学习记17 分钟前
从0死磕全栈之Next.js 数据安全实战指南:从零信任到安全架构
前端
云中雾丽19 分钟前
flutter中 getx 的使用
前端
Jay丶36 分钟前
聊聊入职新公司两个月,试用期没过这件事
前端·面试
ZTeam前端全栈进阶圈40 分钟前
Vue新技巧:<style>标签里的 CSS 也能响应式!
前端
ღ_233341 分钟前
vue3二次封装element-plus表格,slot透传,动态slot。
前端·javascript·vue.js
摸着石头过河的石头44 分钟前
JavaScript继承的多种实现方式详解
前端·javascript
ybb_ymm1 小时前
前端开发之ps基本使用
前端·css
Ashley的成长之路1 小时前
NativeScript-Vue 开发指南:直接使用 Vue构建原生移动应用
前端·javascript·vue.js