0


Jmeter并发比例的控制方法

**

【概述】

**
在使用jmeter的时候,需要对业务并发比例进行设置,可以一个业务对应一个线程组,设置数量进行并发比例设置,但这种方式不科学,因为并发事务数量依赖于事务响应时间,如果某个线程组内的取样器响应时间比较慢时,就影响最终的并发事务了。因此在同一个线程组中设置并发比例,是比较合理的。

**

【需求背景】

现在有个被测支付系统,支付业务有 微信被扫、支付宝被扫、公众号支付三个业务,模拟其并发比例为2: 3:5。

以下是通过随机数的生成概率来控制并发权重

【操作步骤】

**
1、现在线程下面,设置“用户自定义变量”,比如RunNum,起到占位作用。 路径:配置元件—>用户自定义变量。

在这里插入图片描述

2、在线程组下面,添加“仅一次控制器”,然后添加beanshell,对RunNum进行赋值,值是使用随机函数生成的。

在这里插入图片描述

在这里插入图片描述
*
beanshell代码:vars.put(“RunNum”,Integer.toString(${__Random(1,100,)}));
beanshell代码解读:生成1~100的随机数,赋值给RunNum*

3、添加如果(if)逻辑控制器,控制随机数落在一个区间的时候,则触发下面的事件。

例如控制代码:
KaTeX parse error: Expected group after '_' at position 2: {_̲_groovy({runNum} < 20)} #如果RunNum小于20,那么就执行控制器下面的微信被扫取样器*
在这里插入图片描述
*KaTeX parse error: Expected group after '_' at position 2: {_̲_groovy({runNum} >= 20 && ${runNum} < 50)}
#如果RunNum大于等于20且小于50,那么就执行控制器下面的支付宝被扫取样器

在这里插入图片描述
KaTeX parse error: Expected group after '_' at position 2: {_̲_groovy({runNum} >= 50}
#如果RunNum大于50,那么就执行控制器下面的支付宝被扫取样器

在这里插入图片描述

这样就可以实现并发比例的控制了。

总结

在各种并发比例控制方法中,这种是比较简单且容易理解的了。
其原理就是通过随机数“落点”区间的概率大小来控制并发。

标签: jmeter 压力测试

本文转载自: https://blog.csdn.net/weixin_40374541/article/details/127943787
版权归原作者 小昆虫抓bug 所有, 如有侵权,请联系我们删除。

“Jmeter并发比例的控制方法”的评论:

还没有评论