Jmeter基础使用指南
如何安装jmeter
先下载JAVA:https://www.oracle.com/java/technologies/downloads/#java17
安装后配置java的环境变量,当打开CMD命令提示符,输入 java -version有输出即可
下载地址:https://jmeter.apache.org/download_jmeter.cgi

下载后解压缩到英文路径目录下
将jmeter根目录路径和bin文件夹路径添加到环境变量完成配置
如何用Jmeter执行接口测试
在jmeter解压的文件夹中按bin路径找到jmeter.bat打开

选择切换中文语言

添加接口集
右键测试计划,选择添加线程组

添加HTTP请求

将完整的请求拆分,填入各个项,例如登录接口:
POST http://192.168.2.11:8086/api/v1/auth/login

我们正常可以把通用的请求头内容改为变量,添加一个用户定义变量


将请求字段改成调用变量的形式

POST请求需要额外建一个请求头配置元件:HTTP信息头管理器,并添加属性值,如Content-Type = application/json(需根据实际数据类型填写,例子接口传输数据类型是json)。

我们同时可以添加其他各种header里面的内容

针对我们post接口要发送json格式的数据,需要将参数的名称设为空,value值是要post的json字符串。

执行接口前,先添加一个监听器用来查看结果

然后点击执行,结果即可在监听器中查看

如何解决中文响应内容乱码问题
中文内容输出乱码解决办法:
找到jmeter.properties文件

在1098行找到#sampleresult.default.encoding=ISO-8859-1

修改成utf-8,重启jmeter即可

成功后即可输出正常的中文

如何快捷生成请求
如果接口已经发布,可以在浏览器中查询到接口调用,可以通过F12开发者模式获取接口执行的内容
选择对应的接口,右键->复制->以cURL(BASE)格式复制

然后在jmeter中选择以cURL格式导入即可


然后可以通过生成的请求,修改参数等做展开测试
如何同接口调用不同参数依次运行
可以使用参数化csv
新建一个excel文件,将参数按执行一轮取一排的形式输入,另存为csv
这里以上面的post接口为例,只有一个json结构的参数:

在jmeter中新建一个CSV 数据文件设置

根据实际情况选择各个字段的值

参数详解:
l 名称(Name):脚本中显示的该元件的描述性名称,必须填写。
l 注释(Comments):对该元件的说明信息。(非必填写)
l 文件名(Filename):待读取文件的名称。可以写入绝对路径,也可以写入相对路径(相对于bin目录或者脚本文件所在目录),如果直接写文件名,则该文件一定要放在bin目录中。对于分布式测试,主机和远程机中相应目录下应该有相同的CSV文件,必须填写。(建议填写相对路径,避免脚本迁移时需要修改路径)
l 文件编码(File Encoding):文件读取时的编码格式,不填则使用操作系统的编码格式。(非必填写,下拉菜单可选,一般情况下选择UTF-8即可)
l 变量名称(Variable Names):变量名列表。对应参数文件每列的变量名,类似Excel文件的文件头,起到标示作用,同时也是后续引用的标识符,建议采用有意义的英文标示。例如:eid,name可以被用变量名来引用:${eid},${name}。多个变量名之间必须用分隔符分隔。如果该项为空,则文件首行会被读取并解析为列名。(非必填写)
l 忽略首行(Ignore first line):是否忽略首行,如果CSV文件中没有表头,则选择False,必须填写。
l 分隔符(Delimiter):参数分隔符,将一行数据分隔成多个变量,默认为逗号,也可以使用\t。如果一行数据分隔后的所获得的变量数,比Vairable Names中定义的变量少,这些变量将保留以前的值(如果有值的话),必须填写。
l 是否允许带引号?(Allow quoted data?):是否允许变量使用双引号,允许的话,变量将可以括在双引号内,并且这些变量名可以包含分隔符。(非必填写)
l 遇到文件结束符再次循环?(Recycle on EOF?):是否循环读取CSV文件内容,默认为 True,必须填写。因为CSV Data Set Config组件一次读入一行,分割后存入若干变量中交给一个线程组,如果线程数超过文本的记录行数,那么可以选择从头再次读入;
1)为True时,当已读取完参数文件内的测试用例数据,还需继续获取用例数据时,此时会循环读取参数文件数据(即:读取文件到结尾时,再重头读取文件);
2)为False时,若已至文件末尾,则不再继续读取测试数据;通常在“线程组的线程数“或者”线程组的循环次数“>参数文件组数时,选用False(即:读取文件到结尾时,停止读取文件);
l 遇到文件结束符停止线程?(Stop thread on EOF?):如果线程数超过了数据文件中的变量,是否停止,默认为 False。当Recycle on EOF为True时,此项无意义。
l 线程共享模式(Sharing mode):共享模式,即参数文件的作用域。如果希望每个线程拥有自己独立的值集合,那么就需要创建一系列数据文件,为每个线程准备一个数据文件,如test1.csv、test2.csv等,使用文件的方式test${__threadNum}.csv,并将Sharing mode设置为Current thread。
1)所有线程All threads(默认):文件在所有线程间共享。即当前测试计划中的所有线程组中的所有的线程都有效。
2)当前线程组Current thread group:每个文件会针对每个线程组打开一次。即:对当前线程组中的线程有效。
3)当前线程Current thread:每个文件会针对每个线程单独打开。即:对当前线程有效。
因为有2条数据,所以设置2次循环,或者设置2个线程也行

点击执行后就会分别取2套参数运行


如何引用其他接口的响应数据
例如登录接口获取的token:
选择添加json提取器

按对应路径结构填写path

路径方法参考:Json表达式语法规则

可以在响应结果中,修改显示格式为JSON path tester,通过JSON语法试试能不能取到预期结果


添加BeanShell取样器

可以通过函数助手实现表达式

属性名称代表设置为全局变量的名称
存储结果就是json提取器提取出来的名称,即上面填的names of created variables,直接在这里引用即可

我们新增一个需要在header中带authorization的get接口

在header中引入变量${__property(token)}

执行后发现参数已经引用成功了
