之前我们有写过Jmeter多人并发抢1个红包,今天我们来写另外一种场景,同用户重复并发多次抢红包,两种场景还是不太一样,都是比较切合用户实际使用场景,如果1个用户在某些条件下,能重复领取到2次红包,这肯定是存在严重漏洞的,这里又可以分为2种情况,一种是间隔重复领取,另一种是并发重复领取。当然第一种一般是不会出现的,接口都会做限制;第二种是比较常出现的问题,需要加锁防止并发操作导致的重复领取,前端也需要做防重提交操作,这样就比较保险了。
一、添加setup前置线程组,设置线程数为1,为了让同用户只登登录1次
二、将登录接口放置仅一次控制器里,保证登录接口只执行一次
三、配置登录接口,参数一般传在消息体里
四、登录成功,可以看到token值,可以配置提取token提取器了
五、配置Json提取器,提取token值
六、提取器后面添加beanshell后置处理器,参数里配置提取器里面的变量值,将提取的token值,设置为全局变量${__setProperty(requestToken,${Token},)};
七、添加并发线程组,线程数配置21
八、线程组下配置请求头,传入全局变量token(${__property(requestToken)})
九、业务上操作发红包,红包数6个,每个0.01,数据库生成红包编号,配置抢红包接口
十、执行并发线程组,发现只有1个接口是抢成功的,其它20个都是 系统繁忙,请勿重复点击!说明是加了锁的报的提示,没有造成同一个人并发领取的问题。
十二、我们再将线程组设置为循环2次
十三、加了固定定时器,循环领取2次,提示 您已领取过,无法重复领取!,说明也是正常的,不存在重复领取的问题