软件测试 —— jmeter(2)

软件测试 —— jmeter(2)

  • HTTP默认请求头(元件)
  • 元件作用域和取样器作用域
  • HTTP Cookie管理器
  • 同步定时器
  • jmeter插件
  • 梯度压测线程组(Stepping Thread Group)
      • 参数解析
      • 总结
  • Response Times over Time
  • Active Threads Over time
  • 聚合报告
  • 测试报告
      • 性能分析
        • 响应时间
        • 错误率(可靠性)
        • 吞吐量

上一次我们简单介绍了一下jmeter和简单使用了一下jmeter,今天我们继续介绍一下jmeter中的其他插件:

HTTP默认请求头(元件)

我们之前创建了一个HTTP请求,我们的手动输入信息:
在这里插入图片描述如果我们有很多的HTTP请求,每一个我们都要手动输入的话,那就太麻烦了,所以我们可以默认配置HTTP的默认请求:

在测试计划上右击:
在这里插入图片描述在这里插入图片描述
里面填上相应的信息:
在这里插入图片描述这个时候我们可以把原来HTTP请求中信息抹掉:
在这里插入图片描述这个时候点击运行:
在这里插入图片描述并且我再添加HTTP请求,都是会按照我们默认请求值里面的信息配置:
在这里插入图片描述

元件作用域和取样器作用域

如果我们此时再创建一个线程组,添加HTTP请求:
在这里插入图片描述这个时候,HTTP请求3会报错:
在这里插入图片描述我们发现HTTP请求3没有按照之前的配置填入信息,但此时我把HTTP请求默认值给它拉到外面:
在这里插入图片描述在这里插入图片描述
此时请求通过了,这就说明我们改变了HTTP请求默认值元件的作用范围。
在这里插入图片描述在这里插入图片描述这就要谈到元件取样器的作用范围了
元件作用域只对它的子节点有作用

在这里插入图片描述
取样器(sampler)元件内组件不依赖其他元件就可执行,因此取样器不存在作用问题
在这里插入图片描述

HTTP Cookie管理器

我们还有另外一个元件,HTTP Cookie管理器
在这里插入图片描述HTTP Cookie管理器像Web浏览器⼀样存储和发送Cookie。如果HTTP请求并且响应包含cookie,则Cookie管理器会⾃动存储该cookie,并将其用来于将来对该特定网站的所有请求。每个JMeter线程都有自己的"cookie存储区"。因此,正在测试使用cookie存储会话信息的⽹站,则每个JMeter线程都将拥有自己的会话。此类Cookie不会显⽰在Cookie管理器显⽰屏上,可以使⽤"查看结果树监听器"查看。

缓存配置可选择standard(标准)或compatibility(兼容的),当然也可以手工添加⼀些cookie.添加了HTTP Cookie管理器后,会自动存储并发送Cookie。

同步定时器

我们看到右上角的黄色三角形符号:
在这里插入图片描述点击之后会进入到界面,这个时候,我们再次运行:
在这里插入图片描述
我们就可以看到各个线程的执行情况,我们看到所有的线程并不是同一时间准备好的,这样我们无法模拟并发的场景,这个时候我们要添加同步计时器
在这里插入图片描述在这里插入图片描述

模拟用户组的数量和线程组的数量是一致的。这里注意一下,配置好之后放到全局范围我们再来看:
在这里插入图片描述我们发现两个线程组是同时启动的,这样就可以模拟并发场景了。

jmeter插件

如果我们还想要安装其他的插件,我们就要安装一下小蝴蝶
点击这个跳到对应官网:

https://jmeter-plugins.org/install/Install/

在这里插入图片描述
在这里插入图片描述
下载好了之后,把插件移动到lib下的ext下:
在这里插入图片描述
关闭jmeter之后,再次打开,右上角就会多了一个小蝴蝶的标志:
在这里插入图片描述
点击进去就可以搜索下载对应的插件:
在这里插入图片描述
我们先安装一个线程组的插件:
在这里插入图片描述
点击下方的Apply,就会安装好了重启,之后我们右击查看关于线程组的元件多了两个:

在这里插入图片描述
然后我们安装一下extra,帮助我们看到结果:
在这里插入图片描述

梯度压测线程组(Stepping Thread Group)

右击,添加梯度压测线程组(Stepping Thread Group)
在这里插入图片描述在这里插入图片描述
我们来解释一下这几个参数是啥意思:
在这里插入图片描述
这张图显示了JMeter中线程组(Thread Group)的调度参数配置。以下是各个参数的详细解析:

参数解析

  1. This group will start [number] threads:
  • 设置为 100:表示这个线程组将启动100个虚拟用户(threads)。
  1. First, wait for [number] seconds:
  • 设置为 0:表示在启动任何线程之前,等待0秒。这意味着线程会立即开始执行。
  1. Then start [number] threads:
  • 设置为 0:表示在等待时间结束后,立即启动0个线程。这里设置为0,意味着不会立即启动任何线程。
  1. Next, add [number] threads every [number] seconds, using ramp-up [number] seconds:
  • 设置为 20 threads every 3 seconds, using ramp-up 3 seconds:
    • 表示每3秒增加20个线程,并且每个线程的启动间隔为3秒。
    • 例如,在第3秒时启动第一个线程,在第6秒时启动第二个线程,以此类推,直到所有20个线程都启动完毕。
  1. Then hold load for [number] seconds:
  • 设置为 6:表示在所有线程启动后,保持负载(即所有线程都在运行)6秒。
  1. Finally, stop [number] threads every [number] seconds:
  • 设置为 20 threads every 10 seconds:
  • 表示在保持负载6秒后,每10秒停止20个线程。
  • 例如,在第7秒时停止前20个线程,在第17秒时停止接下来的20个线程,以此类推,直到所有线程都停止。

总结

  • 初始阶段
  • 立即启动0个线程。
  • 每3秒增加20个线程,每个线程的启动间隔为3秒。
  • 负载保持阶段
  • 在所有线程启动后,保持负载6秒。
  • 停止阶段
  • 每10秒停止20个线程,直到所有线程都停止。

为了能够看到启动了梯度压测线程组的变化,我们也得添加一些监听器:

Response Times over Time

右击添加,Response Times over Time:
在这里插入图片描述
在这里插入图片描述这样我们在启动的时候,就会在这上面看到实际的情况,记得往线程组中添加请求:
在这里插入图片描述在这里插入图片描述

Active Threads Over time

我们还可以添加Active Threads Over time来查看线程的活动情况:
在这里插入图片描述在这里插入图片描述

聚合报告

从聚合报告可以看到性能测试过程中整体的数据变化:
在这里插入图片描述
在这里插入图片描述

指标说明
Samples发起的 HTTP 请求调用数
Average平均响应时间,单位为毫秒
Median请求调用响应时间的中间值,也就是 50% 请求调用的响应时间,单位为毫秒
90%Line90% 请求调用的响应时间,单位为毫秒
95%Line95% 请求调用的响应时间,单位为毫秒
99%Line99% 请求调用的响应时间,单位为毫秒
Min请求调用的最小响应时间,单位为毫秒
Max请求调用的最大响应时间,单位为毫秒
Error%调用失败的请求占比。调用失败一般指响应断言失败或者请求调用出错
ThroughputTPS/QPS,每秒处理的事务数
KB/sec每秒网络传输的流量大小,单位为 KB。这个指标是以网络传输的大小来衡量网络的吞吐量

测试报告

JMeter测试报告是⼀个全面而详细的文档,它提供了关于测试执行结果的详细信息,帮助用户全面评估系统的性能并进行性能优化。

生成性能测试报告的命令:

Jmeter -n -t 脚本文件 -l 日志文件 -e -o ⽬录
-n : 无图形化运⾏
-t : 被运行的脚本
-l : 将运行信息写入志文件,后缀为jtl的日志文件
-e : 生成测试报告
-o : 指定报告输出目录

在这里插入图片描述执行成功之后会有对应的报告文件:
在这里插入图片描述在这里插入图片描述

性能分析

通过三大指标来分析性能问题:

响应时间

定义:响应时间是指从客户端发出请求到接收到服务器响应的整个过程所需的时间。

瓶颈指示:如果响应时间超过了要求,这可能意味着系统已经到达了其处理能力的极限或存在其他性能瓶颈。

注意事项

  • 分析在多少线程的情况下发生了响应时间超标的情况。
  • 注意响应时间的变化趋势,以确定是否存在系统不稳定的问题。

响应时间变化的原因

  • 系统不稳定:系统有时快有时慢,可能是由于资源竞争、负载不均等因素导致。
  • 并发压力增大:随着并发用户的增加,响应时间可能会逐渐变长,表明系统在高负载下的性能下降。
错误率(可靠性)

定义:错误率衡量的是系统在高并发场景下能否正常处理业务请求的能力。通常要求达到极高的可靠性标准,如99.99%或更高。

错误率高的原因

  • 接口请求错误:API调用失败,可能是由于参数错误、网络问题等。
  • 服务器无法继续处理:当服务器达到其处理极限时,可能导致错误率上升。这可能是由于代码质量问题、内存泄漏或其他硬件资源限制。
  • 后端系统限流、熔断、降级:为了保护系统的稳定性,可能会对某些服务实施限流措施,或者在检测到异常时采取熔断和降级策略。

什么是熔断、降级?

  • 熔断:防止系统因某个服务的故障而整体崩溃。例如,在电商平台上用户支付时,若发现某支付渠道(如微信支付)失败率突增或超时严重,可以临时将该支付方式熔断,即停止使用这一渠道以保护系统的其余部分。
  • 降级:主动关闭一些非核心功能,确保核心功能的正常运行。例如,腾讯视频在出现问题时,用户名默认显示为“腾讯用户”,这是一种降级方式,使用兜底名称进行展示以保证基本服务的可用性。
吞吐量

定义:吞吐量指的是单位时间内系统能够处理的请求数量。一般而言,吞吐量越大,性能越好。

吞吐量变化规律

  • 波动很大:这代表系统性能不稳定,可能存在资源分配不合理等问题。
  • 慢慢变高,再趋于稳定:这种模式通常与并发量强相关。随着并发量从小到大逐渐增加,吞吐量也会相应增长,直到达到一个稳定的水平。
  • 慢慢变低,并发量也减少了:这可能是性能测试接近尾声,人为减少并发量的结果;但也可能是系统变得卡顿,响应时间变慢,从而导致单个线程发起的并发量减少。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

分子动力学模拟里的术语:leap-frog蛙跳算法和‌Velocity-Verlet算法

分子动力学模拟(Molecular Dynamics Simulation,简称MD)是一种基于经典力学原理的计算物理方法,用于模拟原子和分子在给定时间内的运动和相互作用‌。以下是关于分子动力学模拟的一些核心术语和概念: ‌定义系统‌&am…

在 Windows 11 中为 SMB 3.x 文件共享协议提供 RDMA 支持

注:机翻,未校。 Enable SMB Direct in Windows 11 在 Windows 11 中启用 SMB Direct Provides RDMA support for the SMB 3.x file sharing protocol 为 SMB 3.x 文件共享协议提供 RDMA 支持 Vigneshwaran Vijayakumar November 3, 2024 Last Updat…

zabbix6.0安装及常用监控配置

文章目录 部署zabbix-serverzabbix监控节点部署解决zabbix中文乱码创建主机组创建模版配置主机与模版关联 监控boot分区监控网卡流量出网卡流量监控进入和出的总流量监控内存监控服务器端口用户自定应监控key值 (监控mysql查询数量)zabbix触发器监控cpu监控入网卡流量 邮件告警…

如何将使用unsloth微调的模型部署到ollama?

目录 一、将模型保存为gguf格式 二、下载llama.cpp 三、生成 llama-quantize 可执行文件 四、使用llama-quantize 五、训练模型 六、将模型部署到ollama 一、将模型保存为gguf格式 在你的训练代码 trainer.train() 之后添加: model.save_pretrained_gguf(&q…

【Hadoop面试题2025】

文章目录 简单题故障及相应的处理方法中等难度高难度小文件小文件的产生小文件问题的影响小文件治理方案推荐方案 冷文件冷文件的产生冷文件问题的影响冷文件治理方案推荐方案 简单题 一、基础概念类 什么是Hadoop? 答案:Hadoop是一个开源的分布式计算框…

2025.1.21——六、BUU XSS COURSE 1 XSS漏洞|XSS平台搭建

题目来源:buuctf BUU XSS COURSE 1 目录 一、打开靶机,整理信息 二、解题思路 step 1:输入框尝试一下 step 2:开始xss注入 step 3:搭建平台 step 4:利用管理员cookie访问地址 三、小结 二编&#…

[论文阅读] (36)CS22 MPSAutodetect:基于自编码器的恶意Powershell脚本检测模型

《娜璋带你读论文》系列主要是督促自己阅读优秀论文及听取学术讲座,并分享给大家,希望您喜欢。由于作者的英文水平和学术能力不高,需要不断提升,所以还请大家批评指正,非常欢迎大家给我留言评论,学术路上期…

IPhone16 Plus 设备详情

目录 产品宣传图内部图——前内部图——后设备详细信息 产品宣传图 内部图——前 内部图——后 设备详细信息 信息收集于HubWeb.cn

PyTorch入门 - 为什么选择PyTorch?

PyTorch入门 - 为什么选择PyTorch? Entry to PyTorch - Why PyTorch? by JacksonML $ pip install pytorch安装完毕后,可以使用以下命令,导入第三方库。 $ import pytorch

Jmeter 动态参数压力测试时间段预定接口

🎯 本文档详细介绍了如何使用Apache JMeter进行压力测试,以评估预定接口在高并发场景下的性能表现。通过创建线程组模拟不同数量的用户并发请求,利用CSV文件动态配置时间段ID和用户token,确保了测试数据的真实性和有效性。文档中还…

字节跳动自研HTTP开源框架Hertz简介附使用示例

字节跳动自研 HTTP 框架 Hertz Hertz 是字节跳动自研的高性能 HTTP 框架,专为高并发、低延迟的场景设计。它基于 Go 语言开发,结合了字节跳动在微服务架构中的实践经验,旨在提供更高效的 HTTP 服务开发体验。 1. 背景介绍 随着字节跳动业务…

Spring Boot 自定义属性

Spring Boot 自定义属性 在 Spring Boot 应用程序中,application.yml 是一个常用的配置文件格式。它允许我们以层次化的方式组织配置信息,并且比传统的 .properties 文件更加直观。 本文将介绍如何在 Spring Boot 中读取和使用 application.yml 中的配…

HarmonyOS Next构建工具 lycium 原理介绍

HarmonyOS Next构建工具 lycium 原理介绍 背景介绍 HarmonyOS Next中很多系统API是以C接口提供,如果要使用C接口,必须要使用NAPI在ArkTS与C间交互,这种场景在使用DevEco-Studio中集成的交叉编译工具,以及cmake构建工具就完全够用…

数据结构(Java)——二叉树

1.概念 二叉树是一种树形数据结构,其中每个节点最多有两个子节点,通常被称为左子节点和右子节点。二叉树可以是空的(即没有节点),或者由一个根节点以及零个或多个左子树和右子树组成,其中左子树和右子树也分…

ansible自动化运维实战--script、unarchive和shell模块(6)

文章目录 一、script模块1.1、功能1.2、常用参数1.3、举例 二、unarchive模块2.1、功能2.2、常用参数2.3、举例 三、shell模块3.1、功能3.2、常用参数3.3、举例 一、script模块 1.1、功能 Ansible 的 script 模块允许你在远程主机上运行本地的脚本文件,其提供了一…

【期末速成】Oracle数据库

选择题 从中选 10 道。 Oracle的管理与开发工具不包括( D )。 A. OEM B. SQL*PLUS C. ONCA D. PHP PHP 是一种编程语言,不是 Oracle 的工具。 下面文件属于物理文件的是( C )。 A. 概要文件 B. 闪回文件 C. 数据文件 D…

auto的用法

文章目录 一、auto 一、auto 在这里插入代码片在这里插入代码片感谢大家能看到这里,多多支持!

UE求职Demo开发日志#7 强化属性完善

1 实现思路设计 定义一个结构体记录技能树一个单元的信息&#xff0c;命名为FStrengthenCellInfo&#xff0c;一个TArray记录技能树整体信息&#xff0c;需要以下信息&#xff1a; 1.TArray前置技能index 2.FString 描述文本 3.TArray<FMyItemInfo>激活需要的物品ID和…

java常量池

目录 1 Class常量池 2 运行时常量池 3 字符串常量池 3.1 为什么要设计字符串常量池 3.2 字符串对象三种创建姿势 3.3 字符串的操作 3.4 字符串的不可变性 4 包装类型常量池 1 Class常量池 class 文件的资源仓库javap命令可以查看class常量池 主要包含字面量和符号引用字面量 由…

C语言-内存管理

1、malloc()函数 用于动态分配一块指定大小的内存&#xff0c;并返回指向这块内存的指针。如果分配失败&#xff0c; 返回 NULL。 int* ptr (int*)malloc(sizeof(int) * 10); // 分配一个包含 10 个整数的内存 if (ptr NULL) {printf("Memory allocation failed!\n&q…