07、JMeter 教程 - JMeter配置元件

1.简介

JMeter配置元件可以用来初始化默认值和变量,读取文件数据,设置公共请求参数,赋予变量值等,以便后续采样器使用。将在其作用域的初始化阶段处理。配置元件(Config Element)提供对静态数据配置的支持,可以为取样器设置默认值和变量。

首先我们来看一下JMeter的配置元件,路径:添加-配置元件;我们可以清楚地看到JMeter5中共有20个配置元件,如下图所示:

 

2.常用配置元件详解

由上而下地详细地讲解一下常用的配置元件。

2.1 CSV Data Set Config

1、 我们先来看看这个CSVDataSetConfig长得是啥样子,如下图所示:;

 

2、 参数详解及说明,如下表所示:;

参 数

描 述

是否必填

Name

脚本中显示的这个元件的描述性名称

Filename

待读取文件的名称。可以写入绝对路径,也可以写入相对路径(相对于bin目录),如果直接写文件名,则该文件要放在bin目录中。对于分布式测试,主机和远程机中相应目录下应该有相同的CSV文件

File Encoding

文件读取时的编码格式,不填则使用操作系统的编码格式

Ignore first line

是否忽略首行,如果csv文件中没有表头,则选择false

Variable Names

变量名列表,多个变量名之间必须用分隔符分隔。如果该项为空,则文件首行会被读取并解析为列名列表

Delimiter

参数分隔符,将一行数据分隔成多个变量,默认为逗号,也可以使用“\t”。如果一行数据分隔后的值比Vairable Names中定义的变量少,这些变量将保留以前的值(如果有值的话)

Allow quoted data?

是否允许变量使用双引号,允许的话,变量将可以括在双引号内,并且这些变量名可以包含分隔符

Recycle on EOF?

是否循环读取csv文件内容,达到文件结尾后,是否从文件开始循环重新读取;默认为 true

Stop thread on EOF?

是否循环读取csv文件内容,达到文件结尾后,线程是否该终止;默认为 true

Recycle on EOF?

当Recycle on EOF为False时,停止线程,当Recycle on EOF为True时,此项无意义,默认为 false

Sharing mode

1、All threads(默认):一个线程组内,各个线程(用户)唯一顺序取值;2、current thread:一个线程组内,各个线程(用户)各自顺序取值;3、线程组各自独立,但每个线程组内各个线程(用户)唯一顺序取值;

3、 RecycleonEOF和StopthreadonEOF的关系:;

当Recycle on EOF 选择true时,Stop thread on EOF选择true和false无任何意义,因为既然前面已经设置了文件是不停的循环读取,后面的控制stop就相当于失效; 当Recycle on EOF 选择false时,Stop thread on EOF选择true,则当线程数超过文件里的参数的个数时,实际请求数为参数的个数; 当Recycle on EOF 选择false时,Stop thread on EOF选择flase,当线程数超过文件里参数的个数时,实际请求次数为线程数,但当线程数超过参数次数时,由于没有参数,所以结果仍然是失败的。 4、Sharing mode:如果希望每个线程拥有自己独立的值集合,那么就需要创建一系列数据文件,为每个线程准备一个数据文件,如test1.csv、test2.csv等,使用文件名test${__threadNum}.csv,并将“sharing mode"设置为"Current thread"

Allthreads:文件在所有线程间共享。

Identifier:所有线程共享相同的标识,共享相同的文件。如有4个线程组,测试人员可以使用一个通用ID,以便在两个或多个线程组之间共享文件。

Current thread:每个文件会针对每个线程单独打开。

Current thread group:每个文件会针对每个线程组打开一次。

2.2 HTTP Header Manager

支持用户添加或者重写HTTP请求头。JMeter支持多个信息头管理器。多个信息头条目合并成一个信息头列表,跟随http请求一并提交到服务端。

注意:敲黑板,敲脑壳!!!

(1)当有多个信息头管理器,且不同的管理器内有名称相同的信息头条目存在时,顺序靠前的管理器的信息头条目会覆盖后面的;

(2)当只有一个信息头管理器,但管理器内有名称相同的信息头条目时,会同时生效;

1、 我们先来看看这个HTTPHeaderManager长得是啥样子,如下图所示:;

 

2、 参数详解及说明,如下表所示:;

参数

描述

是否必填

Name

请求头的名称,比如Content-Type

Value

请求头的值,比如application/json

3、 常用请求头,这些一般可以抓包和在浏览器中查到,如下表所示:;

 

2.3HTTP Cookie Manager

主要有两个功能:

一个功能是:像web浏览器一样存储和发送Cookie。如果有一个HTTP请求和相应里包含Cookie,Cookie管理器会自动存储Cookie,那么接下来针对特定web站点的所有请求中使用该Cookie。可在结果树中查看。

接收到的Cookie可以被保存为变量,须定义属性"CookieManager.save.cookie=true"。另外,在被存储前Cookie名称会加上前缀“COOKIE_",要恢复早前处理方式,则定义属性”CookieManager.name.prefix="(一个或多个空格)。

如果启动了该功能,那么名称为TEST的Cookie,可以通过${COOKIE_TEST}加以引用。手动为Cookie管理器添加一个Cookie(为所有JMeter线程所共享)。

1、 我们先来看看这个HTTPCookieManager长得是啥样子,如下图所示:;

 

2、 参数详细说明,如下表所示:;

参数

描述

是否必填

Name

树中显示此元件描述的名称

Comments

注释

Clear cookie each Iteration

每次线程组运行前,都会清楚cookie,但是如果是手动添加的cookie,不会被清除

Cookie Policy

选择Cookie的管理策略,建议选择兼容性,兼容性强

User Define cookie

用户自定义cookie

2.4HTTP Cache Manager

被用来为其作用域内的HTTP请求提供缓存功能,如果“Use Cache-Control/Expires header When ..."选中,那么会根据当前时间来选择,如果请求是”GET",而时间指向未来,那么采样器就会立即返回,而无须从远程服务器请求URL,这样是为了模拟浏览器的操作,请注意Cache-Control头必须是“pulic”的,并且只有"max-age"终结选项会被处理,如果请求文档自从其被缓存以来没有发生任何改变,那么响应包体就会为空。

1、 我们先来看看这个HTTPCacheManager长得是啥样子,如下图所示:;

 

2、 参数详细说明,如下表所示:;

参数

描述

是否必填

Name

树中显示此元件的描述性名称

Comments

注释

Clear Cache each iteration

如果选择此选项,则在线程开始时清除缓存。

Use Cache

如果选择此选项,则在线程开始时使用缓存。

Max Number

如果选择此选项,则在线程开始时最大缓存。

2.5HTTP Request Defaults

在实际测试计划中,我们经常会碰到Http Sampler请求有较多的参数与配置会重复,每一个Http Sampler都单独设置的话比较浪费时间和精力,为了节省工作量,JMeter提供了HTTP Request Defaults元件,用来把这些重复的部分封装起来,一次设置多次使用。可以设定一些缺省值,假设有10个请求,访问域名和端口都是一样的,那HTTP请求中就不再需要单独配置了,比较方便(增加脚本的移植性)。

这个元件可以设置HTTP请求控制器使用的默认值。例如,图中【服务器名称或IP】项目内填入了【example.com】,后面的HTTP请求如果IP也是example.com的话,那么只要将【服务器名称或IP】留空,那么这个字段将自动继承HTTP请求默认值中的值。其他诸如【协议】、【端口号】、【路径】等同此。

1、 我们先来看看这个HTTPRequestDefaults长得是啥样子,如下图所示:;

 

2、 参数详细说明,如下表所示:;

参数

描述

是否必填

Name

用作标识一个取样器,建议使用一个见名知义的名称

Comments

注释

Protocol

协议,向目标服务器发送HTTP请求时的协议,可以是http或者是Https

IP

HTTP请求发送的目标服务器名称或者IP地址

Port Number

目标服务器端口

Path

目标URL路径(不包括服务器地址和端口)

Content encdoing

内容的编码方式

Parameter

参数

body data

参数

2.6Counter

计数器,顾名思义就是在测试执行过程中会记录迭代次数。可以在线程组任何位置创建,允许用户配置起点、最大值和增量。配置后,计数器将从起点循环到最大值,然后重新开始,直到线程结束。允许用户创建一个计数器,可在线程组中任何地方被引用。

1、 我们先来看看这个Counter长得是啥样子,如下图所示:;

 

2、 参数详细说明,如下表所示:;

参数

描述

是否必填

Name

控制器名称,可以随意设置

Comments

注释,可以随意设置

Starting value

启动,记录数量起始值

Increment

递增,记录迭代次数步长,1后是2,步长就是1

Maximum value

记录的最大值

Number format

计算器格式,可以是数字,例如000000(6位长度,000,000(6位长度,3位间隔开);字符加数字,例如CUST_000000(字符加6位数字 )

Exported Variable Name

引用变量名称,记数器记录的值可以存入的此引用名(变量),可供其他元件调用

Track counter independently for each user

与每位用户独立的跟踪计数器,每个线程都有自己的计数器,相互不干扰

Reset counter on each Thread Group Iteration

每次迭代复原计数器

2.7DNS Cache Manager

1、 我们先来看看这个DNSCacheManager长得是啥样子,如下图所示:;

 

2、 参数详细说明,如下表所示:;

参数

描述

是否必填

Name

树中显示此元件的描述性名称

Comments

注释

Clear cache each iter

清除每个迭代的缓存,如果选择此选项,则每次启动新迭代时,都会清除每个线程的DNS缓存。

Use System DNS resolver

使用系统DNS解析器;将使用系统DNS解析器。为了正确工作,请编辑 $ JAVA_HOME / jre / lib / security / java.security并添加networkaddress.cache.ttl = 0

Use custom DNS resolver

使用自定义DNS解析器;将使用自定义DNS解析器(来自dnsjava库)。

2.8FTP Request Defaults

被用于设置FTP请求的默认值

1、 我们先来看看这个FTPRequestDefaults长得是啥样子,如下图所示:;

 

2.9HTTP Authorization Manager

HTTP认证是一种安全机制,在客户端、浏览器或者程序向服务器发起请求时,需要提供用户名和密码且验证通过(拿到凭证)才能继续发起交互。

1、 我们先来看看这个HTTPAuthorizationManager长得是啥样子,如下图所示:;

 

2.10JDBC Connection Configuration

1、 我们先来看看这个JDBCConnectionCOnfiguration长得是啥样子,如下图所示:;

 

2、 关于JDBCConnectionCOnfiguration参数详细说明,可以参考六;

2.11Java Request Defaults

1、 我们先来看看这个JavaRequestDefaults长得是啥样子,如下图所示:;

 

2.12Keystore Configuration

1、 我们先来看看这个KeystoreConfiguration长得是啥样子,如下图所示:;

 

2、 参数详细说明,如下表所示:;

参数

描述

是否必填

Name

树中显示此元件的描述性名称。可以默认

Comments

注释

Preload

预载,是否预加载秘钥库,设置为true通常是最佳选择

Variable name holding certificate alias

变量名称,将包含用于客户端证书身份验证的别名。例如,将从CSV数据集中填充变量值。在屏幕截图中,“ certificat_ssl”也将是CSV数据集中的变量。

Alias Start index

从0开始在Keystore中使用的第一个键的索引。

Alias End index

基于0的密钥库中要使用的最后一个密钥的索引。使用“变量名称持有证书别名”时,请确保其足够大,以便在启动时加载所有密钥。

2.13LDAP Extended Request Defaults

1、 我们先来看看这个LDAPExtendedRequestDefaults长得是啥样子,如下图所示:;

 

2.14LDAP Request Defaults

1、 我们先来看看这个LDAPRequestDefaults长得是啥样子,如下图所示:;

 

2.15Login Config Element

1、 我们先来看看这个LoginConfigElement长得是啥样子,如下图所示:;

 

2.16Random Variable

1、 我们先来看看这个RandomVariable长得是啥样子,如下图所示:;

 

2、 参数详细说明,如下表所示:;

参数

描述

是否必填

Name

树中显示的此元件的描述性名称。

Comments

注释

Variable Name

变量名,存储随机字符串的变量的名称。

Output Format

格式化字符串,要使用的java.text.DecimalFormat格式字符串。例如,“ 000”将生成至少3位数字,或者“ USER_000”将生成USER_nnn形式的输出。如果未指定,则默认为使用Long.toString()生成数字。

Minimum Value

最小值;生成的随机数的最小值(长整数)。

Maximum Value

最大值;生成的随机数的最大值(长整数)。

Seed for Random function

随机种子,随机数生成器的种子。默认值为当前时间,以毫秒为单位。如果在“将每个线程”设置为true的情况下使用相同的种子值,则与“ 随机” 类一样,您将为earch线程获得相同的值

Per Thread(User)?

每个线程,如果为False,则在线程组中的所有线程之间共享生成器。如果为True,则每个线程都有自己的随机生成器。

2.17Simple Config Element

1、 我们先来看看这个SimpleConfigElement长得是啥样子,如下图所示:;

 

2、 参数详细说明,如下表所示:;

参数

描述

是否必填

Name

树中显示此元件的描述名称

Comments

注释

Name

参数名称

Value

参数值

2.18TCP Sampler Config

TCP采样器配置为TCP采样器提供默认数据

1、 我们先来看看这个TCPSamplerConfig长得是啥样子,如下图所示:;

 

2、 参数详细说明,如下表所示:;

参数

描述

是否必填

Name

树中显示此元件的描述性名称

Comments

注释

TCPClient classname

TCPClient类的名称,默认属性tcp.handler,使TCPClientImpl失败

Sever Name or IP

TCP服务器的名称或者IP

Port Number

使用的端口

Re-use connection

重用连接,如果选择,则连接保持打开状态,否则,在读取数据后将其关闭

Close connection

关闭连接,如果选择此项,则在运行采样器后将连接关闭

Set NoDelay

设置节点布局,应该设置nodelay

SO_LINGER

创建套接字时,以指定的延迟时间(以秒为单位)启用/禁用SO_LINGER。如果将“SO_LINGER"值设置为0,则则可以防止大量套接字处于TIME_WAT 的状态

End of line byte value

判断行结束的byte值,如果你指定的值大于127或者小于-128,则会跳过EOL检测。比如服务器端返回的字符串都是以回车符结尾,那么我们可以将该选项设置成10。

Text to send

文字发送,要发送的文字

Connect

连接超时(毫秒。0禁用)

Response

响应超时(毫秒。0禁用)

2.19User Defined Variables

如果您有多个线程组,请确保对不同的值使用不同的名称,因为UDV在线程组之间共享。同样,这些变量在处理完元素之后才可用,因此您不能引用在同一元素中定义的变量。您可以引用在早期UDV或测试计划中定义的变量。

1、 我们先来看看这个UserDefinedVariable长得是啥样子,如下图所示:;

 

2、 参数详细说明,如下表所示:;

参数

描述

是否必填

Name

树中显示此元件描述的名称

Comments

注释

User Define Variables

用户定义的变量。变量名称/值对。您需要在$ {...}结构的方括号内放置“名称”(Name)列下的字符串,以便以后使用变量。然后,整个$ {...}将由“值”列中的字符串替换