JMeter详细介绍和相关概念

在这里插入图片描述

JMeter是一款开源的、强大的、用于进行性能测试和功能测试的Java应用程序。
在这里插入图片描述

本篇承接上一篇 JMeter快速入门示例 , 对该篇中出现的相关概念进行详细介绍。

JMeter测试计划

  1. 测试计划名称和注释:整个测试脚本保存的名称,以及对该测试计划的注释。这些自定义内容最好能表达脚本的意义。

  2. 用户定义的变量:在测试计划上可以添加用户定义的变量,这些变量相当于是全局变量,一般添加一些系统常用的配置。但请注意,如果测试过程中想切换环境或配置,一般不建议在测试计划上添加变量,因为不方便启用和禁用。此时,可以直接添加用户自定义变量组件。

  3. 线程组设置

    • 独立运行每个线程组:用于控制测试计划中的多个线程组的执行顺序。如果不勾选,则默认各线程组并行、随机执行。勾选后,可以保证线程组按顺序执行。
    • Run tearDown Thread Groups after shutdown of main threads:当线程组停止运行时仍继续运行tearDown线程组。该选项结合线程组的执行配置使用,但一般很少用到。
  4. 函数测试模式:如果选中了此选项,同时监听组件(如“查看结果树”)配置了保存到一个文件中,那么JMeter会将每次的请求结果保存到文件中。但此操作比较消耗资源,因此一般不建议勾选。

  5. 类路径设置:可以添加文件或jar包。此功能最常用于调用外部jar包。当脚本需要调用外部的java文件或jar包时,可以把jar包路径添加到这里,然后在beanshell中直接import进来,并调用jar包中的方法

线程组

  1. :线程组可以看作是一个虚拟用户组,线程组中的每个线程都可以理解为一个虚拟用户。这些虚拟用户将并发地执行测试计划中的请求,从而模拟真实世界的用户行为,对目标服务器进行压力测试。

  2. 分类

    • 普通线程组:最常见的线程组类型。可以指定线程数、循环次数、延迟等参数,以控制虚拟用户的并发数和请求执行方式。
    • setUp线程组:一种特殊类型的线程组,通常用于执行预测试操作,如数据准备、登录等。与普通线程组不同,setUp线程组会在其他线程组之前执行。这对于需要在测试开始前进行一些初始化操作的情况非常有用。
    • tearDown线程组:另一种特殊类型的线程组,通常用于执行测试后的清理操作,如关闭数据库连接、清理测试数据等。与setUp线程组类似,tearDown线程组会在所有其他线程组执行完毕后执行。
  3. 关键参数

    • 线程数:模拟用户数,多个线程用于模仿对服务器的并发访问。
    • Ramp-Up时间:设置启动所有线程需要的时间,即线程从启动到运行再到释放的总时间。在负载测试时,建议将Ramp-Up时间设置大一些,以便让性能曲线平缓,从而更容易找到瓶颈点。
    • 循环次数:设置线程组中的每个线程循环次数。可以理解为线程的迭代次数或重复发起请求的次数。
  4. 错误处理:在取样器发生错误后,JMeter提供了多种操作选项,包括继续执行接下来的请求、启动下一个线程循环、停止当前线程循环、停止所有线程、停止测试计划以及立即停止测试计划等

取样器

JMeter中的取样器(Sampler)是执行性能测试的关键组件之一,用于模拟用户请求并收集相应的请求和响应数据。

常用取样器

  1. HTTP请求取样器 :用于模拟HTTP请求,测试Web应用程序的性能。它支持HTTPS协议,可以设置请求头、参数化、Cookie管理等。
  2. Debug Sampler:用于在测试过程中输出调试信息,如请求的参数、响应的状态码、响应的内容等。这对于调试测试计划或查看请求和响应的详细信息非常有用。但需要注意的是,Debug Sampler会记录大量的详细信息,可能会导致测试结果文件变得很大,因此不建议在生产环境中使用。
  3. 其他取样器:JMeter还提供了其他类型的取样器,如FTP请求取样器、JDBC请求取样器等,用于模拟不同类型的请求。

使用注意事项

  • 配置元件:在使用取样器时,通常需要配置一些元件,如HTTP Cookie管理器、CSV数据文件设置等,以模拟真实用户的请求环境。
  • 监听器:可以使用监听器查看取样结果,如查看结果树、聚合报告等,以便对测试结果进行分析和评估。
  • 作用域:取样器不存在作用域问题,但其他配置元件、定时器、断言等会作用于范围内的取样器。
  • 执行顺序:取样器是按照树上顺序从上到下执行的,因此需要注意取样器的排列顺序

断言

JMeter中的断言是用于验证服务器响应是否正确的测试元素,它会检查服务器响应中的部分或全部内容,并在响应不符合预期时标记该请求为失败。以下是对JMeter断言的详细介绍:

一、断言的作用

断言在测试过程中起着至关重要的作用,它相当于检查点,用于判断系统返回的响应结果是否正确,从而帮助测试人员判断测试是否通过。通过使用断言,可以确保应用程序的响应满足预期,提高测试的准确性和效率。

二、断言的类型

JMeter提供了多种类型的断言,以适应不同的测试场景和需求。以下是一些常用的断言类型:

  1. 响应断言

    • 用于验证服务器返回的响应内容是否符合预期。
    • 可以对响应文本、响应代码、响应信息、响应头、请求头、请求数据等字段进行断言。
    • 支持多种模式匹配规则,如包括、匹配、相等、字符串等。
  2. JSON断言

    • 专门用于验证响应结果为JSON格式的请求。
    • 可以使用JSON Path表达式来指定要断言的字段和值。
    • 支持对字段值进行正则匹配或精确匹配。
  3. 大小断言

    • 用于验证服务器响应的大小是否在指定范围内。
    • 可以对完整响应、响应头、响应的消息体、响应代码、响应信息等字段进行大小断言。
    • 支持等于、大于、小于、不等于等比较类型。
  4. 持续时间断言

    • 用于验证服务器响应是否在指定时间内返回。
    • 可以设置响应时间范围,任何超过该范围的响应都将被标记为失败。
  5. BeanShell断言

    • 提供了一种自定义断言脚本的方式。
    • 可以使用BeanShell脚本语言编写自己的判断逻辑。
    • 适用于需要复杂逻辑判断的断言场景。
  6. 其他断言

    • JMeter还支持其他类型的断言,如XPath断言、比较断言等。
    • 这些断言类型适用于特定的测试场景和需求。

三、断言的配置

在JMeter中配置断言通常需要在测试计划中选择需要添加断言的Sampler,然后右键单击该Sampler并选择“Add”->“Assertions”->相应的断言类型。在断言配置窗口中,可以设置要检查的字段、匹配规则、预期值等参数。

四、断言的使用注意事项

  1. 选择合适的断言类型:根据测试需求和响应格式选择合适的断言类型。
  2. 设置合理的匹配规则和预期值:确保匹配规则和预期值能够准确反映预期的响应内容。
  3. 注意断言的作用范围:根据需要设置断言的作用范围,如作用于父节点取样器及对应子节点取样器等。
  4. 避免过度使用断言:过多的断言会增加测试计划的复杂性和执行时间,因此应合理控制断言的数量和复杂度。

监听器

JMeter监听器是JMeter测试计划中的重要组件,用于收集和显示测试结果。以下是对JMeter监听器的详细介绍:

一、监听器的作用

  1. 实时收集数据:监听器可以实时收集JMeter测试执行过程中的数据,包括请求和响应的各种信息。
  2. 显示测试结果:监听器以不同的方式展示收集到的测试结果,如树状结构、表格、图形等,便于测试人员直观了解测试情况。
  3. 分析测试结果:通过监听器,测试人员可以对测试结果进行分析和评估,如查看响应时间、吞吐量、错误率等指标,以评估系统的性能表现。
  4. 生成测试报告:监听器可以生成测试报告,汇总测试结果和性能指标,方便团队成员共享和讨论测试结果。

二、监听器的类型

JMeter提供了多种类型的监听器,以适应不同的测试需求和场景。以下是一些常用的监听器类型:

  1. 查看结果树:以树状结构组织显示所有取样器的响应。通过查看结果树,可以查看任意取样器的响应信息,并提供多种不同的视图查看响应结果。但请注意,生成查看结果树需要消耗大量的系统资源(如CPU、内存等),因此在负载测试期间不得使用。
  2. 聚合报告:为测试中的每个不同名称的请求创建一个表记录。对于每个请求,它统计了响应信息并提供请求计数、最小值、最大值、平均值、错误率、近似吞吐量(请求/秒)和每秒千字节吞吐量等关键性能指标。
  3. 后端监听器:可以将事务或采样器在某个时间范围内执行的结果发送给外部系统(如Graphite、InfluxDB等),以便进行进一步的分析和可视化。
  4. 汇总报告:与聚合报告类似,但提供了更详细的测试结果汇总信息。
  5. 汇总图:以图形的方式展示测试结果汇总信息,便于测试人员直观了解测试趋势和性能瓶颈。
  6. 断言结果:用于查看断言的成功和失败数,帮助测试人员定位问题所在。
  7. 响应时间图:以图形的方式展示各事务和采样器的响应时间,便于测试人员分析系统响应时间的变化情况。

三、监听器的配置和使用

在JMeter中配置监听器通常需要在测试计划中选择需要添加监听器的Sampler或线程组,然后右键单击并选择“Add”->“Listener”->相应的监听器类型。在监听器配置窗口中,可以设置相关参数,如文件名、输出格式、匹配规则等。

使用监听器时,需要注意以下几点:

  1. 选择合适的监听器类型:根据测试需求和场景选择合适的监听器类型。
  2. 合理配置参数:根据测试需求合理配置监听器的参数,以确保收集到准确、有用的测试数据。
  3. 注意资源消耗:部分监听器(如查看结果树)会消耗大量的系统资源,因此在负载测试期间应谨慎使用。
  4. 定期查看和分析测试结果:通过定期查看和分析监听器生成的测试结果,可以及时发现和解决问题,提高测试效率和准确性。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/58076.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【原创】统信UOS如何安装最新版Node.js(20.x)

注意直接使用sudo apt install nodejs命令安装十有八九会预装10.x的老旧版本Node.js,如果已经安装的建议删除后安装如下方法重装。 在统信UOS系统中更新Node.js可以通过以下步骤进行: 1. 卸载当前版本的Node.js 首先,如果系统中已经安装了N…

4.1.2 网页设计技术

文章目录 1. 万维网(WWW)的诞生2. 移动互联网的崛起3. 网页三剑客:HTML、CSS和JavaScriptHTML:网页的骨架CSS:网页的外衣JavaScript:网页的活力 4. 前端框架的演变基于CSS的框架基于JavaScript的框架基于MV…

【Django】继承框架中用户模型基类AbstractUser扩展系统用户表字段

Django项目新建好app之后,通常情况下需要首要考虑的就是可以认为最重要的用户表,即users对应的model,它对于系统来说可以说是最基础的依赖。 实际上,我们在初始进行migration的时候已经同步生成了相应的user表,如下&am…

spygalss cdc 检测的bug(二)

当allow_qualifier_merge设置为strict的时候,sg是要检查门的极性的。 如果qualifier和src经过与门汇聚,在同另一个src1信号或门汇聚,sg是报unsync的。 假设当qualifier为0时,0&&src||src1src1,src1无法被gat…

xss-labs靶场第十七关测试报告

目录 一、测试环境 1、系统环境 2、使用工具/软件 二、测试目的 三、操作过程 1、注入点寻找 2、使用hackbar进行payload测试 3、绕过结果 四、源代码分析 五、结论 一、测试环境 1、系统环境 渗透机:本机(127.0.0.1) 靶 机:本机(127.0.0.…

Jenkins发布vue项目,版本不一致导致build错误

问题一 yarn.lock文件的存在导致在自动化的时候,频频失败问题二 仓库下载的资源与项目资源版本不一致 本地跑好久的一个项目,现在需要部署在Jenkins上面进行自动化打包部署;想着部署后今后可以省下好多时间,遂兴高采烈地去部署&am…

提升数据处理效率:TDengine S3 的最佳实践与应用

在当今数据驱动的时代,如何高效地存储与处理海量数据成为了企业面临的一大挑战。为了解决这一问题,我们在 TDengine 3.2.2.0 首次发布了企业级功能 S3 存储。这一功能经历多个版本的迭代与完善后,逐渐发展成为一个全面和高效的解决方案。 S3…

python 实现一个简单的浏览器引擎

1. 浏览器引擎工作原理 浏览器引擎是用来处理、渲染和显示网页内容的核心组件。其主要任务是将用户输入的URL所代表的网页资源加载并呈现出来,通常包括HTML、CSS、JavaScript以及各种多媒体内容。浏览器引擎的工作原理可以分为以下几个主要步骤: 1.1 U…

软件系统建设方案书(word参考模板)

1 引言 1.1 编写目的 1.2 项目概述 1.3 名词解释 2 项目背景 3 业务分析 3.1 业务需求 3.2 业务需求分析与解决思路 3.3 数据需求分析【可选】 4 项目建设总体规划【可选】 4.1 系统定位【可选】 4.2 系统建设规划 5 建设目标 5.1 总体目标 5.2 分阶段目标【可选】 5.2.1 业务目…

FlinkSQL之temporary join开发

在实时开发中,双流join获取目标对应时刻的属性时,经常使用temporary join。笔者在流量升级的实时迭代中,需要让流量日志精准的匹配上浏览时间里对应的商品属性,使用temporary join开发过程中踩坑不少,将一些经验沉淀在…

【开源免费】基于SpringBoot+Vue.JS网上超市系统(JAVA毕业设计)

本文项目编号 T 037 ,文末自助获取源码 \color{red}{T037,文末自助获取源码} T037,文末自助获取源码 目录 一、系统介绍二、演示录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状5.3 可行性分析 六、核心代码6.1 查…

研发运营一体化(DevOps)能力成熟度模型

目录 应用设计 安全风险管理 技术运 持续交付 敏捷开发管理 基于微服务的端到端持续交付流水线案例 应用设计 安全风险管理 技术运 持续交付

Android 判断手机放置的方向

#1024程序员节|征文# 文章目录 前言一、pandas是什么?二、使用步骤 1.引入库2.读入数据总结 需求 老板:我有个手持终端,不能让他倒了,当他倒或者倾斜的时候要发出报警; 程序猿:我这..... 老板…

2024-09-28 地址空间与进程控制

一、进程地址空间 Pt.2 同一个变量,地址相同,其实是虚拟地址相同,内容不同其实是被映射到了不同的物理地址 1. 页表 内存保护与页表标志位 在操作系统中,页表用于管理内存的访问权限。每个页表项通常包含一组标志位&…

二:Python学习笔记--基础知识(1) 变量,关键字,数据类型,赋值运算符,比较运算符

目录 1. 变量 2. python关键字 3. python数据类型 3.1 数字类型 整型 int 浮点型 float 内置函数-type 3.2 字符串类型 3.3 布尔类型 3.4 空类型 3.5 列表类型 3.6 元组类型 3.7 字典类型 4. python赋值运算 5. python比较运算符 1. 变量 组成:必须是数…

基于SSM的BBS社区论坛系统源码

运行环境:ideamysql5.7jdk8maven 使用技术:ssmmysqlshirolayui 功能模块:用户管理、模板管理、帖子管理、公告管理、权限管理等

yolov9目标检测/分割预测报错AttributeError: ‘list‘ object has no attribute ‘device‘常见汇总

这篇文章主要是对yolov9目标检测和目标分割预测测试时的报错,进行解决方案。 在说明解决方案前,严重投诉、吐槽一些博主发的一些文章,压根没用的解决方法,也不知道他们从哪里抄的,误人子弟、浪费时间。 我在解决前&…

Lampiao靶机入侵实战

07-Lampiao靶机入侵实战 一、扫描采集信息 1、获取IP地址 nmap -sn 192.168.81.0/24获得IP地址为:192.168.81.1282、获取端口信息 由于nmap默认情况下只扫描常用的1000个端口,覆盖面并不全,所以建议全端口扫描 nmap -p 1-65535 192.168.…

DiffusionDet: Diffusion Model for Object Detection—扩散模型检测论文解析

DiffusionDet: Diffusion Model for Object Detection—扩散模型检测论文解析 这是一篇发表在CVPR 2023的一篇论文,因为自己本身的研究方向是目标跟踪,之前看了一点使用扩散模型进行多跟踪的论文,里面提到了DiffusionDet因此学习一下。 论文…

读数据工程之道:设计和构建健壮的数据系统21数据获取

1. 数据获取 1.1. 数据获取是将数据从一个地方移动到另一个地方的过程 1.1.1. 数据获取与系统内部获取是不同的 1.2. 数据获取是数据工程生命周期中将数据从源系统移入存储的一个中间步骤 1.3. 数据集成则是将来自不同来源系统的数据组合到一个新的数据集 1.4. 数据获取的…