1.1. 什么是参数化
参数化:是测试脚本的一种常用技巧,可将脚本中的某些输入项使用参数来代替,在脚本中指定参数的取值范围和规则等。
1.2. JMeter参数化方式之使用场景对比
(1) 用户参数:适用于参数取值范围很小的时候使用,一般用户数小于10个时使用
(2) 用户定义的变量:一般用于测试中不需要随迭代变化的参数设置,如:IP、Port
(3) 计数器:适用于参数取值类型为序列值,类似数据库中sequence
(4) CSV 数据文件设置 适用于参数化值比较多时使用,该方法具有更大的灵活性
(5) 函数助手:通过函数方式对数据进行参数,如:随机生成1-100的整数函数${__Random(1,100,)}
1.3. 用户参数(User Parameters)
说明:
(1)用户参数元件可以为每个线程定义用户变量。
(2)每个线程使用一列变量。使用变量的方法:${变量名}。
(3)当线程数多于用户参数中的用户数时,用户数据会被循环使用。
操作路径:前置处理器-》用户参数
配置界面如下:
名称:用户参数,设置用户参数的名称,一般为默认值
注释:说明用户参数的作用,一般为默认值
参数:
可以通过“添加变量”,“删除变量”,“向上”,“向下”操作变量和顺序。
参数可以通过“添加用户”,“删除用户”操作参数化数据组。
每次迭代更新一次:指定用户参数是否只在每次执行经过它的父级控制器时,更新一次值。即控制器内不同取样器的变量值是否为相同值。
(1)当参数值是常量值,则勾选与不勾选,效果是一样的。
(2)当参数值中使用了带有函数的可变值,则勾选和不勾选时,效果是不同的。
若不勾选时,则对于UP(user parameters)作用域内的每个取样器,UP都会更新一次;
若勾选,则对于UP(user parameters)作用域内的每个取样器,UP都不会更新及值相同。
通过例子,对比勾选和不勾选的区别
设置线程组为:2个,运行2次;用户参数配置如上一图:
不勾选时,运行结果:
每一个线程中,线程每个线程使用一列变量;每次获取age变量值,都会变化。
勾选时,测试结果:
1.4. 用户自定义变量(User Defined Variables)
说明:
(1) 一般使用于定义常用但是不变化的值。如相同的服务器IP,端口号等
(2)参数值如果是常量时,所有线程使用的值都是一样的。
(3)参数值为函数时,每个线程内参数值是一样的,每一个线程之间获取不同值。
操作路径:配置元件-》用户自定义变量
配置界面如下:
名称:用户定义的变量,设置名称,一般为默认值
注释:说明用户变量的作用,一般为默认值
参数:
可以通过“添加”,“从剪贴板添加”,“删除”,“向上”,“向下”操作变量名和顺序。
参数中变量值比较长,通过“详细”功能进行查看和更新。
通过例子,说明变量变化情况,设置线程为2个,迭代运行2次。
测试结果:
1.5. 计数器
说明:
(1)允许用户创建一个在线程组之内都可以被引用的计数器。
(2)如果需要引用的数据量较大,且要求不能重复或者需要自增,那么可使用计数器来实现。
(3)计数器允许用户配置一个起点,一个最大值,增量数,循环到最大值,然后重新开始,继续这样,直到测试结束。计数器使用long存储的值,默认的最大值为Long.MAX_VALUE,2^63-1。
操作路径:配置元件-》计数器
配置界面如下:
名称:计数器,一般使用默认值+变量说明
注释:备注,说明计数器作用
starting value:给定计数器的起始值、初始值
递增:每次迭代后,给计数器增加的值
Maximum value:计数器的最大值,如果超过最大值,重新设置为初始值(starting value),默认的最大值为Long.MAX_VALUE,2^63-1(如果持续压测,建议最好不要设置最大值)。
数字格式:可选格式,比如000,格式化为001,002;默认格式为Long.toString(),但是默认格式下,还是可以当作数字使用。
引用名称:用于控制在其它元素中引用该值,形式:$(id}
与每用户独立的跟踪计数器:全局的计数器,
(1)如果不勾选,即全局的,比如线程#1 获取值为1,线程#2获取值还是为1;
(2)如果勾选,即独立的,则每个线程有自己的值:比如线程#1 获取值为1,用户#2获取值为2。
Reset counter on each Thread Group Iteration:可选,仅勾选与每用户独立的跟踪计数器时可用;
(1)如果勾选,则每次线程组迭代,都会重置计数器的值,当线程组是在一个循环控制器内时比较有用。
通过例子,设置线程数为2,循环次数为4个,循环控制器为2:
不勾选,“与每用户独立的跟踪计数器”,测试结果如下:
线程组计数器为全局变量,每次线程迭代时都递增一次值。当达到最大值时又重新开始。
勾选,“与每用户独立的跟踪计数器”;不勾选,“Reset counter on each Thread Group Iteration”;时,测试结果如下:
每一个线程启动,单独启动一个计数器进行计数。
勾选,“与每用户独立的跟踪计数器”;勾选,“Reset counter on each Thread Group Iteration”;时,测试结果,如下:
每一个线程启动,单独启动一个计数器进行计数,并且在每一次迭代时递增一次值。
1.6. csv配置文件(CSV Data Set Config)
说明:
通过读取 CSV 文件中的数据并将它们拆分为变量;
操作路径:配置元件-》
配置界面如下:
文件名:指保存信息的文件目录,可以相对或者绝对路径。
(1) 这里要包括文件的路径,在4.0版本中可以点击右侧的浏览按钮选择文件,会自动带上文件的绝对路径;
(2) 当csv文件在jmeter的bin目录或脚本目录时,只需给出文件名即可;
(3) 使用相对路径时,jmeter默认先去bin目录下查找,然后去脚本目录下查找;
文件编码:编码格式,选择utf-8
变量名称:给csv文件中各列起个名字(有多列时,用英文逗号隔开列名)便于后面引用
忽略首行:是否忽略首行;如:一般参数化文件中第一行为列名;如为true时,不取第一行数据;如为false时,取第一行作为参数化数据。
分隔符:与 .csv文件的分隔符保持一致。如文件中使用的是逗号分隔,则填写逗号;如使用的是TAB,则填写;
是否允许带引号:控制csv文件中的双引号是否为有效字符;
(1) 如果数据带有双引号且此项设置True,则会自动去掉数据中的引号使能够正常读取 数据,且即使引号之间的内容包含有分隔符时,仍作为一个整体而不进行分隔;
文件中"2,3"时逗号为分隔符,解析为2,3
(2) 如果数据带有双引号且此项设置为False,则会双引号当作普通字符串处理;
文件中"2,3"时逗号为分隔符,解析为”2和3”
(3) 如果希望双引号字段中间再包含双引号,则需要加两个双引号来代表单个双引号。
此项设置为true时,文件中"4""5"时,解析为4"5
遇到文件结束符再次循环:到了文件尾是否循环,True—继续从文件第一行开始读取,False—不再循环;
遇到文件结束符停止线程:到了文件尾是否停止线程,True—停止,False—不停止;注:当”遇到文件结束符再次循环”设置为True时,此项设置无效。
线程共享模式:
All threads:所有线程,所有线程循环取值,线程1取第一行,线程二取下一行。
Current thread group:当前线程组,各个线程组分别循环取值。
Current thread:当前线程,该测试计划内的所有线程都取第一行。
通过例子,设置线程数为2,循环次数为3个,循环控制器为2:
csv设置如下:
csv文件内容:
测试结果如下: