性能工具之 JMeter 常用组件介绍(二)

举报
zuozewei 发表于 2024/08/08 14:19:49 2024/08/08
【摘要】 性能工具之 JMeter 常用组件介绍(二)

本文主要介绍JMeter Thread Group 和主流断言组件的功能

一、Thread Group

线程组也叫用户组,是性能测试时的虚拟用户资源池,该组件可以用来设置运行时间和虚拟并发数。

具体组件结构如下:在这里插入图片描述

参数说明:

  • Name:线程组的名称,可以随意修改

  • Comments:备注信息,记录一些参数设置的原因和策略可填可不填

  • Action to be taken after a Sampler error:线程内的采样器失败后,接下来采取的动作:

    • Continue:继续执行接下来的操作
    • Start Next Thread Loop:执行下一个线程循环
    • Stop Thread:退出该线程,不在执行该线程的任何操作
    • Stop Test:等待该线程的采样结束后,结束整个测试,不会立即停止
    • Stop Test Now:立即停止整个测试
  • Thread Properites:线程属性

    • Number of Threads(users):线程数,也就是一共要启动多少线程用来并发执行
    • Ramp-uo Period(in seconds):多长时间将上一步设置的线程数启动完毕。设置不同的值可以验证在不同并发的情况下验证系统的性能
    • Loop Count:设置sampler循环的次数,勾上Lnfinte后就会死循环一直执行
    • Specify Thread lifeTime:调度器,日程表。选上之后才能设置执行时间

操作说明:

  • Loop Count: 如果勾选就不断重复
    在这里插入图片描述

不会停止,除非自己停止服务;
在这里插入图片描述
按次数执行:
在这里插入图片描述

View Results Tree 结果:
在这里插入图片描述
按时间执行:
在这里插入图片描述

View Results Tree:
在这里插入图片描述

二、断言组件

在做性能测试中判断是不可缺少的组件,jmeter叫断言(Assertion),它的作用和loadrunner中的检查点类似;用于检查测试中得到的响应数据等是否符合预期,用以保证性能测试过程中的数据交互与预期一致。
jmeter中断言的方式也有很多,我们只介绍以下最常用的几种。

以下是Jmeter中断言截图,其实在工作中只有掌握常见的几种满足工作,如果把断言全部学习,也可以参考官方文档或者自己把每个断言尝试下。
在这里插入图片描述

1、Response Assertion:响应断言

操作步骤:
在这里插入图片描述
添加断言内容:
在这里插入图片描述

作用:用来做检查点,对sampler做额外的检查,比如判断响应数据中是否存在指定的内容,也可以对请求数据做断言。

参数说明:

  • Apply to:指定断言的作用范围
  • Main sample and sub-sample:作用于主main sample和子sub-sample
  • Main sample only:只作用于main sample
  • Sub-samples only:只作用于sub-sample
  • JMeter Variable name to use:作用于JMeter变量

注意:

  • 1.大多数情况下,可只勾选“main sample only”,因为一般情况下,发起一个请求,实际就只有一个请求。但是在某些情况下,发起一个请求时,会触发多个服务器请求,这时候就有main sample和sub-sample之分,类似ajax请求,另外,如果发起重定向请求,并且勾选“跟随重定向”, 则把重定向后的请求视为main-sample。
  • 2.如果sub-sample断言失败,但main sample断言成功,那么main sample也被设置为失败状态。如果作用域JMeter变量,且该变量关联main sample,那么如果断言失败,则main sample也被设置为失败(If the JMeter variable option is used, it is assumed to relate to the main sample, and any failure will be applied to the main sample only)。
  • 3.如果执行完每个sampler的所有断言,变量JMeterThread.last_sample_ok会被设置为true或false。

Field to test:

  • Text Response:断言服务器返回的响应文本,比如body,不包含HTTP headers
  • Response Code :断言响应码, 比如 200
  • Response Message:断言响应码的具体信息,比如 OK
  • Response Headers:断言响应头,包括Set-Cookie 头,如果有的话
  • Resquest Headers:断言请求头
  • URL Sampled:
  • Document(text) -通过Apache Tika追踪的各种各种类型文档的文本
  • Ignore Status:指示JMeter设置sampler status的初始状态为success。sample status是否成功,由
  • Response status和断言结果决定,当选中Ignore Status时,Response status被强制设置为success,不执行进一步的断言判断。仅第一次断言时使用。
  • Resquest Data:断言请求数据
  • Pattern Matching Rules:模式匹配规则
    • Contains:如果文本中包含指定的正则表达式则为true
    • Matches:如果整个文本匹配指定的正则表达式则为true
    • Equals:如果整个文本等于给定的字符串(大小写敏感),则为true
    • Substring:如果整个文本包含给定的字符串(大小写敏感),则为true
    • Not:表示非,不匹配给定的模式,可以和前4个配合使用
    • Or:表示或,和前4个配合使用,有一个为true则为true
      在这里插入图片描述
      注意:
  • Contains,Matches:将字符串当做正则表达式处理
  • Equals,Substring:纯字符串,不会解析成正则表达式,大小写敏感

示例:用Substring模式和contains模式分别匹配:.*
Substring模式,将.*当做文本来匹配,所以会匹配失败
在这里插入图片描述
结果:
在这里插入图片描述

Contains模式:
在这里插入图片描述

结果:
在这里插入图片描述

  • Patterns to Test: 填写需要测试的模式列表, 每个模式都单独测试,如果某个模式失败了,不会往下检查剩余的模式。添加一个断言,多个测试模式(通过重复点击面板的添加按钮来添加多个测试模式),和多个断言,每个断言一个模式是一样的。
    在这里插入图片描述
    在这里插入图片描述
    演示:
    在这里插入图片描述

提示成功:
在这里插入图片描述
断言失败:
在这里插入图片描述

结果:
在这里插入图片描述

2、Response Assertion:响应断言

添加正在【Regular Expression Extractor】
在这里插入图片描述

打开结果查看树【View Results Tree】

在这里插入图片描述

打开后置处理器组件中的【Regular Expression Extractor】:
在这里插入图片描述

输入内容:
在这里插入图片描述

说明:

  • (1)引用名称:下一个请求要引用的参数名称,如填写title,则可用${title}引用它。
  • (2)正则表达式:
    • ():括起来的部分就是要提取的。
    • .:匹配任何字符串。
    • +:一次或多次。
    • ?:抑制贪婪,在找到第一个匹配项后停止。
  • (3)模板:用$$引用起来,如果在正则表达式中有多个正则表达式,则可以是$2$$3$等等,表示解析到的第几个值给title。如:$1$ 表示解析到的第1个值
  • (4)匹配数字:有多个匹配值时,0代表随机取值;正数n代表取第n个匹配的值;负数代表将变量名和数字拼接,比如如果写-1的话,那么拼接后的变量就是title_1。通常情况下填0
  • (5)缺省值:如果参数没有取得到值,那默认给一个值让它取。

添加调试
在这里插入图片描述

结果查看树验证
在这里插入图片描述

3、Duration Assertion:响应时间断言

设置服务器响应的最大时间,如果超过设定的值则认为执行失败,组件如下:
在这里插入图片描述

结果显示:
在这里插入图片描述

参数说明:

  • Apply to:适用范围,也就是断言范围
  • Main sample only:只作用在主sample中
  • Sub-sample only:只作用在子sample中
  • Main sample and Sub-sample only:主sample和子sample中都起作用
  • Duration in milliseconds:响应允许的最大时间,单位为毫秒,超过此值即测试失败。

演示:
设置10ms
在这里插入图片描述

运行结果:
在这里插入图片描述
设置1000ms
在这里插入图片描述

结果显示:
在这里插入图片描述

4.、JSON Assertion:json断言

在这里插入图片描述
具体显示:

在这里插入图片描述
说明:

作用:对响应的json数据断言,查找指定的内容

参数说明:

  • Assert JSON Path exists:符合json path规则的断言表达式,json断言的规则就是json path,和xpath类似也是有类似根和子节点的概念,对比如下:
  • 在这里插入图片描述

json断言的表达式可以使用点运算符也可以使用括号;

  • Additionally assert value:勾选了此项之和才能在Excepted value中填写断言值
  • Match as regular expression:以正则的方式匹配,默认勾选
  • Excepted value:断言值
  • Excepted null:断言空值,断言的数据为null的话可以勾选此项,或者在Excepted value中直接写null
  • Invert assertion (will fail if above condition met):取反,也就是不包含断言表达式中的内容才成功

待演示数据:
在这里插入图片描述

增加json断言【正确】
在这里插入图片描述

结果:
在这里插入图片描述

断言失败:
在这里插入图片描述

验证结果:
在这里插入图片描述

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。