JMeter使用详解

前言

Apache JMeter 是 Apache 组织基于 Java 开发的压力测试工具,用于对软件做压力测试。
JMeter官方文档:Apache JMeter - Apache JMeter™


一、JMeter常用组件

  • 测试计划: 起点,所有组件的容器
  • 线程组: 线程组是一系列线程的集合,每一个线程代表着一个正在使用应用程序的用户。在 jmeter 中,每个线程意味着模拟一个真实用户向服务器发起请求
  • 取样器: 取样器是用来模拟用户操作的,向服务器发送请求以及接收服务器的响应数据
  • 逻辑控制器: 结合取样器实现一些复杂的逻辑
  • 前置处理器: 在请求之前进行的工作
  • 后置处理器: 在请求之后进行的工作
  • 定制器: 负责在请求质检的延迟间隔。固定、高斯、随机
  • 配置元件: jmeter提供了丰富的配置元件,常用的包括参数化配置元件、HTTP请求默认值、HTTP信息头管理器、计数器等,这些配置元件用于设置默认值和变量,提供给后面的sampler(取样器)使用
  • 断言:让程序判断预期结果和世界结果是否一致
  • 监听器: 负责收集结果
  • 执行顺序: 测试计划-->线程组-->配置元件-->前置处理器-->定时器-->取样器-->后置处理器-->断言-->监听器
  • 作用域: 辅助组件(除测试计划、线程组、取样器之外的组件)作用于父组件、同级组件,以及同级组件下的所有子组件

1.线程组

右击测试计划>>>添加>>>Threads(Users)>>>线程组

线程组元件可以理解为一个测试计划的开始(jmeter其它的元件都要放在线程组下)线程组是一系列线程的集合,每一个线程代表着一个正在使用应用程序的用户。在 jmeter 中,每个线程意味着模拟一个真实用户向服务器发起请求。在 jmeter 中,线程组组件运行用户设置线程数量、初始化方式等等配置。例如,如果你设置线程数为 100,那么 jmeter 将创建并模拟测试 100 个用户请求到服务器端。

在取样器错误后要执行的动作
(1)继续:继续执行接下来的操作
(2)Start Next Thread Loop: 开始下一次循环
(3)停止线程:退出该线程,不在执行此线程的操作
(4)停止测试:等待当前执行的采样器结束后,结束整个测试
(5)Stop Test Now:立刻停止测试


线程属性
(1)线程数:相当于模拟的用户数量,一个用户占一个线程,模拟200个用户就是200个线程
注:进行参数化时,需配置对应的线程数量
(2)Ramp-Up Period (in seconds):设置多长时间内启动全部线程。例如线程数为100,时间设定为10s,那么就是10s加载 100个线程,每秒启动的线程数=100/10=10
(3)循环次数: 如果填具体的数值,就是循环对应的次数,例如线程数为200,循环次数为10,则每个线程发10次请求;如果选择“永远”,则一直执行下去,直到手动停止
(4)Delay Thread creation until needed:默认不勾选,测试开始时,所有的线程就被创建完。勾选此项,延迟线程创建,直到需要才创建
调度器配置
(1)持续时间(秒): 脚本持续运行的时间
(2)启动延迟(秒):脚本延迟启动的时间

2.Sampler


1、HTTP请求
选择线程组右键>>>添加>>>Sampler>>>HTTP请求

Basic
(1)协议:向目标服务器发送http请求时的协议,http/https,大小写不敏感,默认http
(2)服务器名称或IP: http请求发送的目标服务器名称或者IP地址,比如www.baidu.com
(3)端口号:目标服务器的端口号,默认值为80
HTTP请求
(1)方法:发送http请求的方法,例:GET\POST
(2)路径:目标的URL路径(不包括服务器地址和端口)
(3)Content encoding:内容的编码方式(Content-Type=application/json;charset=utf-8)
(4)自动重定向:如果选中该项,发出的http请求得到响应是301/302,jmeter会重定向到新的界面
(5)Use keepAlive:jmeter 和目标服务器之间使用 Keep-Alive方式进行HTTP通信(默认选中)
(6)Use multipart/from-data for HTTP POST:当发送HTTP POST 请求时,使用
parameter: 请求 URL 中添加参数,函数定义中参数,而argument指的是函数调用时的实际参数,简略描述为:parameter=形参(formal parameter)
Body Data: 实体数据,就是请求报文里面主体实体的内容,一般我们向服务器发送请求,携带的实体主体参数,可以写入这里
Files Upload: 从HTML文件获取所有有内含的资源:被选中时,发出HTTP请求并获得响应的HTML文件内容后还对该HTML 进行Parse 并获取HTML中包含的所有资源(图片、flash等)

3.配置元件


1、CSV 数据文件设置
CSV 数据文件变量是指从外部 csv 文件读取数据出来作为变量,压测时,如果有动态压测需求,可以在JMeter脚本中添加Config Element:CSV Data Set Config,从CSV文件中读取参数。
选择请求>>>添加>>>配置元件>>>CSV 数据文件设置

设置CSV数据文件
(1)文件名:csv文件路径,可以是绝对路径或者相对路径
(2)文件编码:编码格式,与所选文件编码格式保持一致
(3)变量名称:如果文件中只有一个变量,直接写变量名,如果有多个变量,用英语的逗号隔开
(4)是否允许带引号?:
设置为true,参数文件包含引号时,实际的数据为引号中的数据。比如参数文件中的数据为"1",当使用该参数时,实际取得值为1
设置为false,参数文件包含引号时,实际取得值为全部的值。比如参数文件中的数据为"1",当使用该参数时,实际取得值为"1"
(5)遇到文件结束符再次循环?:
设置为true后,参数文件中的数据循环使用,测试按照线程组中的设置执行。比如csv 文件共有 10 条记录,但线程数有 15 个,循环 10 次后,重头开始循环取值
设置为false后,参数文件不再循环遍历取值
(6)遇到文件结束符停止线程:当执行完参数文件中所有参数后,直接停止线程
(7)线程共享模式:
所有线程(All threads):参数文件对所有线程共享,这包括同一测试计划中的不同线程组(测试计划下的所有线程组下的所有线程共享参数文件,所有线程之前参数取值互相影响,线程在同一次迭代下取值相同)
当前线程组(Current thread group): 只对当前线程组中的线程共享(当前线程组下的所有线程公用一个参数文件,同一个线程组下的线程之前取值相互影响,线程在同一次迭代下取值相同)
当前线程(Current thread): 仅当前线程获取(即每个线程获取一个参数文件,各个线程之间参数取值互不影响,线程在同一次迭代下取值相同)
注:
1)当参数文件的位置与线程组在同级下,线程组下存在循环控制器时,循环控制器下的参数取值相同
2)线程组下存在循环控制器时,当参数文件在循环控制器下,循环控制器下每次迭代时重新取值
3)线程组下存在仅一次控制器,参数文件在仅一次控制器下,当参数在仅一次控制器下取值一次之后,之后无论哪次迭代参数取值都不变,类似于unique once
注:创建CSV文件最好用notepad创建,编码格式为UTF-8

2、HTTP信息头管理器
设置jmeter发送的HTTP请求头所包含的信息

右键>>>添加>>>配置元件>>>HTTP信息头管理器

信息头,也就是请求头,会跟随HTTP请求一起发送到服务器。比如需要传输User-Agent 、cookie、token或其他某些信息,或是需要伪造请求头的时候。

3、HTTP Cookie管理器
右键>>>添加>>>配置元件>>>HTTP Cookie管理器


如果你有一个 HTTP 请求,其返回结果里包含一个 cookie,那么 Cookie 管理器会自动将该 cookie 保存起来,而且以后所有的对该网站的请求都使用同一个 cookie。

4、HTTP请求默认值
管理公用的HTTP请求配置数据
线程组右键>>>添加>>>配置元件>>>HTTP请求默认值

配置线程组下所有【HTTP请求】的请求行和请求体的默认值,与【HTTP请求】放在同级目录。配置后,每个【HTTP请求】无需重复配置,特殊的请求也可以单独配置,单独配置的优先级更高

5、用户定义的变量
选择请求>>>添加>>>配置元件>>>用户定义的变量

引用变量的格式为:${变量名}

优先级:

1、线程组下的用户自定义变量 优先级高于 测试计划里的用户定义的变量

2、HTTP 请求下的用户自定义变量 优先级高于 线程组下的用户定义的变量

注意点:

1、定义的所有参数的值在测试计划的执行过程中不能发生取值的改变。即使变量的值是随机数(Random),不同用户数循环多次,拿到的用户自定义变量值都是一样的

2、一般仅将测试计划中不需要随迭代发生改变的参数(只取一次值的参数)设置在此处

四、定时器


同步定时器(synchronized timer)
选择请求>>>添加>>>定时器>>>同步定时器(synchronized timer)
模拟用户组的数量(Number of Simulated Users to Group by):设置多少用户进行同步操作。设置为0表示执行线程组的线程数,设置为3只会执行三个线程数(假设同步线程组数设置为5)4,5线程执行到这一步会停止。 

注:设置的值不能大于它所在线程组中设置的线程数;0表示 all 无穷大,最大

超时时间(Timeout in milliseconds):以第一个到达同步定时器的用户开始,如果在设置的时间内所有用户都达到了,就立即释放后续操作,如果在设置的时间内还没达到,则目前到达集合点的用户先进行释放做后续操作。 设置为0则一直等待,(以第一个到达为准,到多少走多少),如果设置为3,线程设置为永远循环,每凑够三个就会执行释放

5.前置处理器

jmeter支持的变量
jmeter支持的变量类型:用户自定义变量;函数生成变量;BeanShell 变量;数据文件变量

用户自定义变量
选中请求>>>添加>>>前置处理器>>>用户参数

变量引用格式为:${user}

函数生成变量
内置的函数
点击菜单栏选项>>>函数助手对话框>>>下拉选择>>>选择对应函数


6.后置处理器

 

1、json提取器

JSON是目前大多数接口响应内容的数据格式

在接口测试中,不同接口之间可能会有数据依赖,在Jmeter中可以通过后置处理器来提取接口的响应内容,JSON提取器是其中一个可以用来提取响应内容的元件

  1. Apply to:应用范围,选默认的main sample only就行了
  2. Names of created variables:接收提取值的变量名,多个变量用;分割,必传
  3. JSON Path expression:json path表达式,用来提取某个值,多个表达式用;分割,必传
  4. Match No.(0 for Random):取第几个值,多个值用;分割(0:随机,默认;-1所有;1第一个值),非必传
  5. Compute concatenation var(suffix_ALL):如果匹配到多个值,则将它们都连接卡里,不同值之间用都好分割;变量会自动命名为_ALL
  6. Default Values:缺省值,匹配不到值的时候取该值,可写error;多个值用分号分割;非必传

2、正则表达式提取器

  1. 接口需要关联时,提取接口指定数据
  2. 选择请求右键>>>添加>>>后置处理器>>>正则表达式提取器
  3. 引用名称:请求要引用的变量名称,如填写 result_num
  4. 正则表达式:匹配需要的内容。
  5. 匹配数字:0 代表随机取值,1 代表全部取值,
  6. 缺省值:如果参数没有取得到值,那默认给一个值让它取正则表达式

7.断言


1、响应断言
检查点,比较预期结果与实际结果
选择一个请求右键>>>添加>>>断言>>>响应断言

断言成功,查看结果为绿标;断言失败,查看结果为红标
apply to
(1)Main sample and sub-samples:作用于父节点取样器及对应子节点取样器
(2)Main sample only:只作用于父节点取样器
(3)sub-samples only:只作用于子节点取样器
(4)JMeter Variable Name to use:作用于jmeter变量(输入框内输入变量名称)
要测试的响应字段

  1. 响应文本(Text Response):从服务器返回的响应文本,比如body,包含HTTP头
  2. 响应代码(Response Code) :比如 200、404
  3. 响应消息(Response Message) :比如 OK
  4. Response Headers:响应头,比如 Set-Cookie 头
  5. Document(text):通过Apache Tika追踪的各种类型文档的文本
  6. lonore Status:指示JMeter设置sampler status的初始状态为success。sample status是否成功,由已Response status和断言结果决定,当选中Ignore Status时,Response status被强制设置为success,不执行进一步的断言判断。仅第一次断言时使用

模式匹配规则

  1. 包括:响应内容包括需要匹配的内容即代表响应成功,支持正则表达式
  2. 匹配:响应内容要完全匹配需要匹配的内容即代表响应成功,大小写不敏感,支持正则表达式。
  3. Equals:响应内容要完全等于需要匹配的内容才代表成功,大小写敏感,需要匹配的内容是字符串正则表达式
  4. Substring:返回结果包含指定结果的字串,但是 subString 不支持正则字符串
  5. 否:不进行匹配

Custom failure message: 自定义失败消息

8.监听器

1、察看结果树

察看请求发送和返回的信息

查看结果树可以放在线程组下或者某个配置下,右键>>>添加>>>监听器>>>查看结果树

所有数据写入一个文件
(1)文件名:可以通过浏览,选择一个文件,这样jmeter在执行的过程中,会将所有的信息输出到文件,也支持打开一个结果文件进行浏览
(2)Log/Display Only(显示日志内容):
仅日志错误:表示只输入报错的日志信息
Successes:表示只输出正常响应的日志信息
不勾选:表示输出所有的信息
(3)Configuer:配置需要输出的内容
Search: 在输入框中输入想查询的信息,点击查找(Search),可以在请求列表中进行查询,并在查询出的数据上加上红色的边框
结束数显示类型切换: 通过结果树上面的下来看可以进行切换,包含多种显示方式,默认Text
取样器结果: 取样器的详细结果,可以切换取样器的显示方式Raw/Parsed
请求: 显示当前取样器发送的详细请求内容,支持查找
响应数据: 显示请求得到的响应内容,支持查找
Scroll automaticlly?: 当执行的取样器较多,设置是否滚屏显示

2、聚合报告

聚合报告可以放在线程组下或者某个配置下,右键>>>添加>>>监听器>>>聚合报告

  • Label:请求名称
  • 样本:总共发送到服务器的请求数。
  • 平均值:总运行时间除以发送到服务器的请求数。响应时间 ms(毫秒)
  • 中位数:有一半的服务器响应时间低于该值而另一半高于该值。响应时间 ms(毫秒)
  • 最小值:响应时间 ms(毫秒)
  • 最大值:响应时间 ms(毫秒)
  • 异常%:错误率
  • 吞吐量:是指在一次性能测试过程中网络上传输的数据量的总和。对于交互式应用来说,吞吐量指标反映的是服务器承受的压力
  • 接收KB/sec:每秒接收多少KB
  • 发送KB/sec:每秒发送多少KB

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JMeter报错SAXException时,通常是由于XML解析错误引起的。SAXException是Java中的一个异常类,用于表示在解析XML文档时发生的错误。 XML是一种标记语言,用于存储和传输数据。在JMeter中,XML文件通常用于定义测试计划和测试脚本。当JMeter解析XML文件时,如果文件格式不正确或者存在语法错误,就会抛出SAXException异常。 常见的导致SAXException异常的原因包括: 1. XML文件格式错误:XML文件必须符合规定的格式,包括正确的标签闭合、属性值使用引号包裹等。如果XML文件格式不正确,解析时就会抛出SAXException异常。 2. XML文件编码问题:XML文件应该使用正确的字符编码进行保存,通常是UTF-8。如果XML文件使用了其他编码方式保存,解析时可能会出现编码错误导致SAXException异常。 3. XML文件缺失或损坏:如果XML文件不存在或者损坏,解析时就无法正常进行,从而抛出SAXException异常。 解决SAXException异常的方法包括: 1. 检查XML文件格式:确保XML文件符合规定的格式,可以使用XML验证工具或者在线XML验证服务进行检查。 2. 检查XML文件编码:确认XML文件使用正确的字符编码保存,可以使用文本编辑器查看或者修改编码方式。 3. 检查XML文件完整性:确保XML文件存在且没有损坏,可以尝试重新下载或者使用备份文件。 如果以上方法无法解决问题,可以尝试查看具体的SAXException错误信息,以便更好地定位和解决问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值