码迷,mamicode.com
首页 > 其他好文 > 详细

记录一次并发测试的bug

时间:2020-07-10 19:28:22      阅读:70      评论:0      收藏:0      [点我收藏+]

标签:测试   集合   ade   img   逻辑   产生   线程   参数   alt   

大概具体业务逻辑:创建订单时,通过手机号查找用户,如果找到了直接创建订单,未找到用户就去注册新用户。

问题:业务员发现用户列表有多条相同手机号的用户?

产生问题的原因:由于网络异常等原因,用户发起了多次请求并发生成的

下面是我通过jmeter复现bug产生的原因
1)理论上通过手机号码注册新用户时,会去用户表里面查找该用户是否存在,如果存在就会提示该用户已存在。如下所示:
技术图片
2)创建线程组,给3个线程数
技术图片

2)由于该接口需要先登陆才能发起请求,所以要添加header信息头
技术图片

3)添加http请求,并相应填写请求头和请求参数
技术图片

4)添加集合点(synchronized timer)
技术图片

* [Number of Simulated Users to Group by]: 5”表示并发量是5。也就是说,Jmeter会等到5个线程都运行到此处时,这五个线程才开始执行后面的操作,先到达的线程将会在此等候。
* [Timeout in milliseconds]:超时时间,即多少毫秒后同时释放已集结的的线程,发送测试请求,如果设置为0,Timer将等待线程数达到了"Number of Simultaneous Users to Group"中设置的值才释放。
如果大于0,那么如果超过Timeout in milliseconds中设置的最大等待时间(毫秒为单位)后还没达到"Number of Simultaneous Users to Group"中设置的值,Timer将不再等待,释放已到达的线程

5)添加查看结果树
技术图片
如图所示,发起的三个请求,响应结果都成功了
6)然后我们去数据库查看生产了手机号码相同的三条数据
技术图片
7)开发解决方案是:在数据库给手机号码字段添加了索引

记录一次并发测试的bug

标签:测试   集合   ade   img   逻辑   产生   线程   参数   alt   

原文地址:https://www.cnblogs.com/hghua/p/13280605.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!