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的查看结果树内容分别如下图所示:

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值