JMeter案例分享:通过数据验证的错误,说说CSV数据文件设置中的线程共享模式

前言

用过JMeter参数化的小伙伴,想必对CSV Data Set Config非常熟悉。大家平时更关注变量名称,是否忽略首行等参数,其余的一般都使用默认值。然而我最近遇到一个未按照我的预想读取数据的案例,原因就出在最后一个参数"线程共享模式"上。记录一下,大家避坑。

业务需求及脚本逻辑

某系统用户提交订单之后,在订单列表页面会新增一条记录。

压测前后,需要分别查询订单数量,根据提交订单的成功事务数来判断,是否所有的订单都成功入库。

但是,因为测试过程中多用户并发,每个用户只能查到自己的订单,所以检查时需要逐个检查所有参与并发测试的用户名下的订单数量,然后加总求和。

详情可参见JMeter案例分享:通过采样器自动完成性能测试过程中的功能检查-数据条目验证-CSDN博客

查找问题

脚本调试时,仅使用有限几个账户,一切正常。但是,当项目组提供真正的登录账号后,数据验证总是对不上。于是,减少并发数,并把用户、订单数量信息一一打印出来查看。

原来:

业务前数据检查的用户是usr1、2、3

执行业务的用户是usr4、5、6

业务后数据检查的用户又变成了usr7、8、9

分析原因

它们分属3个线程组,虽然使用的是同一个数据文件,但是因为数据文件是放置在线程组内的,按照我的理解,作用域也应该仅限于本线程组,那么每一个线程组都应该从这个数据文件的第一行开始读取。

然而,事实上,这个数据文件似乎是三个线程组间共享的。

于是,关注到CSV data set config中的共享模式(sharing mode)

官网中对该选项的介绍如下:

  • All threads - (the default) the file is shared between all the threads.(默认值,文件在所有的线程间共享)
  • Current thread group - each file is opened once for each thread group in which the element appears(文件仅在它所在的线程组中被打开一次)
  • Current thread - each file is opened separately for each thread(每个线程都单独打开一份,也就是说,这个文件,每个线程都会独自使用)
  • Identifier - all threads sharing the same identifier share the same file. So for example if you have 4 thread groups, you could use a common id for two or more of the groups to share the file between them. Or you could use the thread number to share the file between the same thread numbers in different thread groups.

下面我们分别设置来看看效果

All threads

默认值,效果前面已经看到了,所有的线程组中的所有线程,共享一个文档,从第一行顺序向下读取。

Current thread group

文件仅在当前线程组中有效,本线程组结束后,下一个线程组将重新打开一遍数据文件,从第一行开始向下读取。这就是我当前这个测试场景中需要的效果。

Current thread

数据文件仅在当前线程中有效。同一个线程组的不同线程间,不共享数据文件。

本例中数据验证线程组是单线程,用循环控制器顺序执行的,看不出效果,看业务线程组:3个并发执行1次,也就是三个线程,但是usr1登录了3次。

也就是说,线程1打开数据文件,从第一行开始读取;

线程2打开数据文件,从第一行开始读取

每个线程读取各自的文件。

Identifier

我在业务前数据验证和业务线程组中分别输入1,标识这两个线程组是group 1

在业务后数据验证线程组中,输入2,标识这是group2

执行结果如下:

红色的两个线程组(group ID为1)作为一个group,共享数据文件。

黄色的线程组(group ID为2)作为一个group,独享数据文件。

遗留问题

最后一种共享模式中这句话我不知道该怎么操作,官网没有示例。

Or you could use the thread number to share the file between the same thread numbers in different thread groups.

相关推荐
hopetomorrow4 小时前
学习路之压力测试--jmeter安装教程
学习·jmeter·压力测试
tester Jeffky13 小时前
JMeter 性能测试计划深度解析:构建与配置的树形结构指南
jmeter
tester Jeffky13 小时前
深入探索JMeter逻辑控制器:构建复杂测试场景的利器
jmeter
tester Jeffky1 天前
深入探索JMeter的执行器时间线:从CLArgsParser到JmeterEngine
jmeter
惜.己1 天前
Jmeter中的断言(二)
测试工具·jmeter·1024程序员节
tester Jeffky1 天前
深入探索JMeter bin目录中的Properties文件:优化性能测试的关键
jmeter
tester Jeffky1 天前
掌握移动端性能测试利器:深入JMeter手机录制功能
jmeter·智能手机
惜.己1 天前
Jmeter中的断言(四)
测试工具·jmeter·1024程序员节
凌云行者1 天前
JMeter的简单使用
jmeter·性能测试
tester Jeffky1 天前
深入探索Apache JMeter:HashTree结构解析与应用
jmeter