JMeter点道为止系列(2)CSV Data Set Config配置Sharing mode解析

JMeter点道为止系列(2)CSV Data Set Config配置Sharing mode解析

 

JMeter性能测试

1 配置解析

在JMeter使用配置元件CSV Data Set Config进行参数化之时,该元件的配置项

Sharing mode的设置往往令人迷惑不解.

"Sharing mode"的中文意思是"线程共享模式",有三个可供选择的值:

1)All threads(所有现场)

2)Current thread group(当前线程组)

3)Current thread(当前线程)

其值的设置会影响到参数取值,为了使参数能获取正确的值来满足特定的业务需求,

有必要深入理解其对参数取值的影响,接下来逐一进行剖析.

1.1 All thread

是指在CSV Data Set Config配置元件作用域范围内的所有线程共享一个数据源文件.

也就是说在JMeter测试执行过程中,JMeter仅打开一次该数据源文件,每个线程读取的

是同一个数据源文件中的数据.

线程按照启动的先后顺序依次从数据源文件中获取一个值,不论该线程是否引用

CSV Data Set Config中定义的变量,每个线程都会分配一个值,这样可以保证每个线程

获取的是数据源文件中不同行的列值(在不循环取值的情况下).

1.2 Current thread group

在CSV Data Set Config配置元件作用域范围内的所有线程组,当JMeter执行测试时,

每一个线程组都单独打开一次数据源文件(可以是相同或不同的数据源文件).

每个线程组下的各个线程都是从数据源文件的起始处读取参数值.

若要线程组读取不同的数据源文件,可以对数据源文件的路径进行参数化.

这里需要使用${__threadGroupName}来获取线程组的名字.

假设有n个线程组:

tg1,tg2,...,tgn

每个线程组对应一个数据源文件,对应的文件名分别为:

tg1.csv,tg2.csv,...,tgn.csv

在配置时将"Filename"设置为".../${__threadGroupName}.csv"即可.

1.3 Current thread

在CSV Data Set Config配置元件作用域范围内的所有线程组,当JMeter执行测试时,

每一个线程都单独打开一次数据源文件(可以是相同或不同的数据源文件).

每个线程都是从数据源文件的起始处读取参数值.

若要线程组读取不同的数据源文件,可以对数据源文件的路径进行参数化.

这里需要使用${__threadNum}来获取线程编号.

假设有n个线程,线程编号为:1,2,...,n

每个线程对应一个数据源文件,对应的文件名分别为:

testdata1.csv,testdata2.csv,...,testdatan.csv

在配置时将"Filename"设置为".../testdata${__threadNum}.csv"即可.

2 案例说明(免费领取Python自动化学习资料  工具,面试宝典面试技巧,加QQ群,785128166,群内还会大佬技术交流)

2.1 All thread案例

1)新建数据源文件testdata.csv,设置其值为:

h

1

2

3

4

5

6

2)配置"Test Plan",勾选"Run Thread Groups consecutively(i.e. one at a time),

  保证线程组按顺序依次执行;

3)添加"CSV Data Set Config",其配置下图所示:

4)在"Test Plan"下添加线程组"tg1",设置线程数为5;

5)在"tg1"下添加HTTP取样器,HTTP请求中没有引用参数p,配置如下图所示:

6)在"Test Plan"下添加线程组"tg2",设置线程数为2;

7)在"tg2"下添加HTTP取样器,HTTP请求中引用了参数p,配置如下图所示:

8)在"tg1","tg2"下分别添加"View Results Tree".

保存并执行测试,tg1,tg2的查看结果树内容分别如下图所示:

 

从结果可以看出,线程组"tg1"的5个线程即使没有引用参数p,也都各自分配了一个值,

线程组"tg1"先于线程组"tg2"启动,线程组"tg2"的2个线程,第一个线程获取了第6个

值"6",第二个线程获取不到值就停止了,所有只显示了一个取样器的结果.

进一步查看jmeter log,可以看出在测试执行过程中testdata.csv只打开一次:

2.2 Current thread group案例

1)新建数据源文件tg1.csv,设置其值为:

h

111

222

333

444

555

666

2)新建数据源文件tg2.csv,设置其值为:

h

aaa

bbb

ccc

ddd

eee

3)配置"Test Plan",勾选"Run Thread Groups consecutively(i.e. one at a time),

  保证线程组按顺序依次执行;

4)添加"CSV Data Set Config",其配置下图所示:

5)在"Test Plan"下添加线程组"tg1",设置线程数为5;

6)在"tg1"下添加HTTP取样器,HTTP请求中引用参数p,配置如下图所示:

7)在"Test Plan"下添加线程组"tg2",设置线程数为2;

8)在"tg2"下添加HTTP取样器,HTTP请求中引用参数p,配置如下图所示:

9)在"tg1","tg2"下分别添加"View Results Tree".

  保存并执行测试,tg1,tg2的查看结果树内容分别如下图所示:

 

### 如何在 JMeter 中调用 CSV 文件进行参数化配置 #### 准备工作 为了使JMeter能够读取CSV文件中的数据,在开始之前需准备好相应的CSV文件。该文件应按照特定格式保存,每列代表不同的变量,而每一行则表示一组测试数据。 #### 添加CSV Data Set Config组件 在JMeter中实现CSV文件的数据参数化主要依赖于`CSV Data Set Config`这一配置元件[^1]。此元件允许用户指定要从中读取数据的CSV文件路径以及定义如何解析这些数据。 - 打开JMeter并创建一个新的线程组或选择已有的线程组。 - 右键击所选线程组 -> `Add` -> `Config Element` -> `CSV Data Set Config`. #### 配置CSV Data Set Config属性 设置好`CSV Data Set Config`之后,需要对其进行适当配置来匹配目标CSV文件结构: - **Filename**: 输入完整的CSV文件路径或者相对路径。 - **Variable Names**: 定义从CSV文件各列映射出来的变量名,多个名称间用逗号分隔。 - **Delimiter**: 设置CSV文件内的字段分隔符,默认情况下为逗号`,`。 - **Quote Character**: 如果CSV中有被引号包围的内容,则在此处填写对应的字符(通常也是双引号"`")。 - **Recycle on EOF?**: 当达到文件结尾时是否重新回到开头继续读取;如果勾选此项,则可以循环利用同一份数据集直到所有线程完成运行。 - **Stop thread on EOF?**: 到达文件末尾后停止当前线程还是让其保持活跃状态等待其他条件触发终止。 - **Sharing mode**: 控制不同线程之间共享同一个CSV文件的方式,可选项有All threads, Current thread group等。 ```properties # Example of properties configuration for CSV Data Set Config element. filename=data.csv variableNames=id,name,email delimiter=, quoteChar=" recycle=true stopThread=false sharingMode=all_threads ``` #### 使用参数化的变量 一旦完成了上述配置步骤,就可以在线程组下的HTTP请求或其他采样器内使用刚才定义好的变量了。只需像`${variablename}`这样引用即可获取对应位置上的实际值。 例如,如果有如下所示的一条记录存在于名为data.csv的文件中: ``` 001,johndoe,john@example.com ``` 那么当执行到含有`${id}`, `${name}`, 和`${email}`占位符的地方时,它们会被替换成为上面那行的具体数值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值