Jmeter实战(二)|同用户重复并发多次抢红包

       之前我们有写过Jmeter多人并发抢1个红包,今天我们来写另外一种场景,同用户重复并发多次抢红包,两种场景还是不太一样,都是比较切合用户实际使用场景,如果1个用户在某些条件下,能重复领取到2次红包,这肯定是存在严重漏洞的,这里又可以分为2种情况,一种是间隔重复领取,另一种是并发重复领取。当然第一种一般是不会出现的,接口都会做限制;第二种是比较常出现的问题,需要加锁防止并发操作导致的重复领取,前端也需要做防重提交操作,这样就比较保险了。

一、添加setup前置线程组,设置线程数为1,为了让同用户只登登录1次

e7febe85da776418526cb456d27df82f.png

二、将登录接口放置仅一次控制器里,保证登录接口只执行一次

fdbf07fc30612f3f757f601b4255aec8.png

三、配置登录接口,参数一般传在消息体里

a012e6ec9838049ea95e492cdb304453.png

四、登录成功,可以看到token值,可以配置提取token提取器了

adf8e050936c5177144c54228cca8870.png

五、配置Json提取器,提取token值

d7e5ef7bc0c94841f110d3d4dc295118.png

六、提取器后面添加beanshell后置处理器,参数里配置提取器里面的变量值,将提取的token值,设置为全局变量${__setProperty(requestToken,${Token},)};

be1bdec2d94c939854ce0f77635c6e43.png

七、添加并发线程组,线程数配置21

74b83ce6a82b1815791784363e53c59d.png

八、线程组下配置请求头,传入全局变量token(${__property(requestToken)})

98aa6b947917c21d7da8d77a6f1cf6c2.png

九、业务上操作发红包,红包数6个,每个0.01,数据库生成红包编号,配置抢红包接口

392e57ac7f32bf509ad5572e94d2074d.png

十、执行并发线程组,发现只有1个接口是抢成功的,其它20个都是 系统繁忙,请勿重复点击!说明是加了锁的报的提示,没有造成同一个人并发领取的问题。

fd3620b3f8c12ac2ae88e450f6710a83.png

66c66360bd169585081b6978e1919716.png

十二、我们再将线程组设置为循环2次

070657196b763d61696dfc5adfb45c60.png

十三、加了固定定时器,循环领取2次,提示 您已领取过,无法重复领取!,说明也是正常的,不存在重复领取的问题

2f5577ff3e84e67b2ade1b276e3b5a12.png

faa7b14601c7508cd12426c95b64aa52.png

猜你喜欢

转载自blog.csdn.net/qq_36502272/article/details/126113215