介绍
Apache JMeter 是一款开源的负载测试工具,主要用于测试静态和动态资源(如Web应用程序)的性能。它能够模拟大量用户对服务器进行访问,并通过图形界面提供详细的性能报告。本指南将介绍如何安装JMeter以及其基本的使用方法。
安装 JMeter
下载
- 访问 JMeter 官方网站获取最新版本。
- 选择适合您操作系统的安装包下载。
- 或者选择文档中的jmeter安装包中的安装文件:apache-jmeter-5.6.3.zip,这个安装包是纯净的安装包,只支持一般功能的使用,要想功能丰富需添加插件,其中在安装包中也放好了一个添加好插件的jmeter安装包:apache-jmeter-5.6.3装了插件的版本.zip
安装步骤
Windows:
解压下载的文件到您希望的位置。
找到 bin 文件夹下的 jmeter.bat (Windows)文件并运行它来启动JMeter。
如果是首次运行,可能需要配置环境变量以确保Java已正确安装且版本符合要求。因为jmeter是java开发的,所以它的运行必须要有java运行环境,否则启动的时候会报错,在运行之前,请先在测试机本地安装配置好jdk。现在安装包中的jmeter需要配置jdk1.8即可。
启动成功后的界面
jmeter启动后,页面默认是英文的,根据需要可进行汉化,在安装路径下的bin目录下修改jmeter.properties配置文件,修改为language=zh_CN、locales.add=zh_CN
启动脚本
打开JMeter后,你会看到一个空白的工作区。接下来我们将创建一个简单的测试计划
添加测试计划
在左侧树形结构中右键点击“测试计划”,添加“线程用户”,选择“线程组”。这表示一组虚拟用户的集合。
配置用户定义的变量
自助机中配置的公共变量
1、创建变量
2、使用变量
配置测试片段
作用:把对应的模块放到对应的位置,支持即插即卸载,每个模块之间都是完全独立的。以自助机压 测为例进行说明:之所以创建三个测试片段是因为进行企保查询操作分为3个阶段,第一阶段 的测试片段是登录自助机,第二阶段测试片段是点击自助机上企保查询功能按钮,跳转到查询 页面并加载所有的静态资源,第三阶段的测试片段是模拟用户输入查询条件并点击查询按钮, 查询出参保缴费的信息。
位置:测试计划--右键--添加--测试片段--测试片段
下一步操作:
1、在测试片段中可以创建各类请求的操作,比如在测试片段中添加http请求
接下来,在循环控制器中添加两个http请求,创建获取登录加密串和就近办自助机登录方法两个http请求,下图是如何创建http请求:
添加HTTP请求体
定义http接口的请求参数,比如IP、端口都可以调用公共变量中的参数,接口可以选择get或者post请求,下面的参数根据接口情况添加参数,下图中发送请求并未添加参数。
配置json提取器
作用:是一个用于从JSON响应中提取数据的元件。它可以从JSON响应中提取特定字段的值,并将这些值用于后续的测试步骤;
位置:右键点击'http请求’-->添加 -->断言--> JSON断言
具体使用:
JSON提取器的配置包括以下几个字段:
1、“name of created variables”:指定一个变量名,用于存储提取的值。
2、“JSON Path expression”:指定一个JSON表达式,用于定位要提取的值。可以使用点号(.)来访问嵌套的字段,例如:“user.name”。
3、“Match Numbers(匹配号)”:指定要提取的值的索引号。如果JSON表达式返回多个匹配项,可以使用匹配号来选择其中一个。(0代表随机,1代表第一个,-1代表所有),可为空即默认第一个。
4、“Compute concatenation var(suffix_ALL)”:是否统计所有,即将匹配到的所有值保存,名为“变量名_ALL”,使用场景需要获取的值有多个,后面需要对这一组数据进行操作。
5、“Default Value”:未取到值的时候默认值。
当配置完JSON提取器后,它将会在每次执行HTTP请求后提取指定字段的值,并将其存储在指定的变量中。可以在后续的测试步骤中使用这些变量。
当使用JMeter的JSON提取器时,可以使用JSONPath语法来定位和提取JSON响应中的特定字段值。
以下是JSONPath语法的详细说明:
$:根节点。使用$表示JSON的根节点。
.:当前节点。使用.表示当前节点。
..:递归下降,用于查找当前节点及其子节点中的匹配项。例如,$.store..price表示查找根节点下的store节点及其子节点中的所有price字段。
*:通配符,匹配任意字段。例如,$.store.*表示匹配根节点下的store节点中的所有字段。
[]:下标操作符,用于选择数组中的元素或对象中的属性。例如,$.store.book[0]表示选择根节点下的store节点中的book数组的第一个元素。
[n]:选择数组中的第n个元素。例如,$.store.book[2]表示选择根节点下的store节点中的book数组的第三个元素。
[start:end]:选择数组中从start到end的元素范围。例如,$.store.book[0:2]表示选择根节点下的store节点中的book数组的前三个元素。
[?(expression)]:过滤器,用于根据表达式的结果筛选匹配项。例如,$.store.book[?(@.price < 10)]表示选择根节点下的store节点中的book数组中价格小于10的元素。
示例:假设有以下JSON响应:
{
"store": {
"book": [
{
"title": "Book 1",
"price": 10
},
{
"title": "Book 2",
"price": 15
},
{
"title": "Book 3",
"price": 5
}
]
}
}
如果想提取第二本书的价格,可以使用JSONPath表达式$.store.book[1].price。这将返回15作为提取的值
添加HTTP请求头
作用:不同情景下,如数据提交形式的不同(例如 JSON、XML 等),或是需要通过 HTTP 头传递特定的认证信息(如使用 JWT 或 OAuth 2.0 令牌)时,比如下图自助机登录,发送这个post请求需要添加http请求头,请求头中包含了必要的参数如上面JSON断言中获取的参数,时间戳和加密串
位置:右键点击 HTTP 请求,选择 添加 > 配置元素 > HTTP 请求头管理器
配置BeanShell断言
作用:使用beanshell脚本来执行断言检查,可以用于更复杂的个性化需求,使用更灵活,功能更强大,但是要能够熟练使用beanshell脚本
位置:线程请求-点击右键-添加-断言-最后一个BeanShell断言
BeanShell断言界面详解
【名称】BeanShell断言组件的自定义名称,见名知意最好。
【注释】即添加一些备注信息,对该BeanShell断言组件的简短说明,以便后期回顾时查看。
【Reset bsh.Interpreter before each call】每个BeanShell测试元素都有自己的解释器副本(对于每个线程)。
如果重复调用测试元素,例如:在循环内,除非选择在每次调用之前重置bsh.Interpreter选项,否则解释器将保留在调用之间。一些长时间运行的测试可能会导致解释器使用大量内存。
由于BeanShell的bsh.Interpreter存在内存泄露,常规方法无法支持长时间的压力测试。
JMeter官网推荐,在使用BeanShell进行长时间测试时,**打开选项【每次调用前置 bsh.Interpreter】=【Reset bsh.Interpreter before each call】,则在每次调用BeanShell程序前,都把解释器重置,以释放解释器之前占用的内存。
【参数 (-> String Parameters和String[]bsh.args)】输入String参数。String[]bsh.args是主类main函数的形式参数,是一个String 对象数组,可以用来获取命令行用户输入进去的参数。
【脚本文件】脚本文件(可以填入脚本文件路径),可以点击后边的浏览选择脚本文件。
【脚本】:编写脚本,参照下文定义的变量(使脚本文件参照定义的变量来运行)
配置线程组
作用:线程组就是控制Imeter用于执行测试的一组用户;
位置:右键点击'测试计划’-->添加 -->线程(用户)--> 线程组
特点: 模拟多人操作线程组可以添加多个,多个线程组可以并行或串行取样器(请求)和逻辑控制器必须依赖线程组才能使用线程组下可以添加其他元件下组件。
配置模块控制器
作用:可以使用模块控制器调用测试片段。前面我们创建了3个测试片段,这些片段想被执行就需要通过模块控制器来调用
位置:右键点击'线程组’-->添加 -->逻辑控制器--> 模块控制器
配置思考时间
作用:设置思考时间是为了模拟用户在实际操作功能时,会有查看及思考的时间,在脚本中也要考虑这部分时间的消耗,在线程组中添加了一个测试活动,设置了停顿时间用来模拟思考。
位置:右键点击'线程组’-->添加 -->取样器--> 测试活动
查看聚合报告
作用:对测试情况做统计。
位置:右键点击'测试计划’-->添加 -->监听器--> 聚合报告
Aggregate Report(聚合报告)参数:
平均值:平均响应时间,所有请求的平均响应时间。
中位数:50%的用户响应时间不超过这个值。
99% Line: 99%的用户响应时间不超过这个值。
Error%:异常百分比。(错误请求的数量/请求的总数)
Throughput:吞吐量,默认情况下每秒完成的请求数。
Received KB / sec:接收数据。
发出请求并查看聚合报告的事例
查看结果树
作用:执行脚本中的请求后,可以在结果树中查看到这些请求是否成功,成功的返回的结果是否正确。
位置:右键点击'测试计划’-->添加 -->监听器--> 查看结果树
作用:
启动脚本
- 在jmeter界面中启动压测脚本,这种只适用于写好测试脚本后,用于测试脚本编写是否正确,线程数等参数也用设置的太大,能测试通即可。
- 通过命令行命令来启动测试脚本,这种是用在实际开始测试的时候使用。因为jmeter本身运行时就有自己的性能瓶颈,在界面直接执行压力比较大的脚本时,页面就会卡死。所以在实际压测时。务必使用命令行的方式启动脚本。
编写执行命令: .\jmeter -n -t C:\Users\Administrator\Desktop\bftest\100bf\jb\100bf.jmx -l C:\Users\Administrator\Desktop\bftest\100bf\test100jg.csv
命令参数说明:
- .\jmeter:必须在jmeter安装目录的bin目录下执行,在这个目录下进去cmd窗口执行脚本。
- C:\Users\Administrator\Desktop\bftest\100bf\jb\100bf.jmx:这个是编写好的压力测试的执行脚本的文件地址;
- C:\Users\Administrator\Desktop\bftest\100bf\test100jg.csv:这个在“I”参数后的地址,是指定执行脚本后生成的测试报告的地址,测试报告的文件扩展名,可以是csv、jtl,这里就生成csv格式的就可以。
生成html报告
jmeter生成的测试文件,需要解析成图表的形式,更便于直观的分析压测的结果,csv合适的分析文件可以通过jmeter自带的工具就可以转换成html格式的测试报告,也可以通过命令行来转换成html格式的测试报告。如下图:
1、jmeter界面解析操作步骤
菜单项中选”工具“--> ”generate HTML report“,进入操作界面。
Results file :选择jmeter生成好的csv测试文件,比如自助机的4g_21000_1630.csv这种类型的文件。
user.properties file : 需要选择jmeter安装目录下的bin目录中的user.properties,这个配置文件。
output directory : 选择将转换好的HTML文件导出的目录,注意,这个目录必须是空的,只用于存放生成好的HTML文件,否则就会导出失败。
2、通过命令来导出HTML文件
如果已经存在结果文件(.csv),可运行如下命令生成报告
jmeter -g 测试结果.csv -o /tmp/测试报告文件夹