【玩转 Postman 接口测试与开发2_019】第15章:利用 Postman 初探 API 性能测试(含实战截图)

server/2025/2/11 3:07:30/

book cover for the 2nd version

《API Testing and Development with Postman》最新第二版封面

文章目录

写在前面
终于来到了本书最后一章 API 性能测试的学习。这一章也是第二版的新增内容,虽然不能算作最后的彩蛋级福利(毕竟性能测试不是 Postman 的专长),但通过几个简单的设置也能在 Postman 进行最基础的性能测试,还是让我非常惊喜的。平时这些功能几乎都没用过,实际操作一遍发现并没有什么难度,既可以作为拓展知识阅读,也可视为今后工作中性能测试的应急方案。
至此,整本书的要点笔记就全部梳理完了,虽然前面还有三章内容没梳理,但都是一些概念性的知识,没有多少提炼的价值,后续可能会放到同一篇博文中一并介绍。相信有了书中介绍的接口测试知识,大家的 Postman 应该称得上熟练甚至小范围精通了。但这只是一个开端,我学 Postman 也是为后面的 AI 学习打下坚实的基础;后续有 Postman 相关的最新动态我也会陆续更新到本专栏,欢迎大家多提意见,共同进步。感谢关注!

第十五章 API 接口性能测试

本章要点

  • 性能负载的不同类型
  • 负载配置文件在 Postman 中的用法
  • 性能测试Postman 中的运行方法
  • 性能测试注意事项

API 接口通过编程进行交互,从而促成了自动化访问,同时也意味着出现性能问题。本章将基于 Postman 简要介绍接口性能测试


1 性能负载的类型

性能测试的复杂之处在于,需要全面综合考虑可能导致系统变慢的各种因素。

性能负载主要可分三类:

  1. 处理负荷(Processing Load):是指处理单元的负荷,可能发生在计算资源开销极为昂贵的任务中;
  2. 内存负载(Memory Load):涉及临时内存(RAM)或存储设备的高内存使用率;
  3. 连接负载(Connection Load):涉及服务器可处理的最大同时连接数等。

2 Postman 负载配置

Postman 实现性能测试,主要是通过 Collection Runner 中的 Performance 配置页实现的:

图 15.1 Postman 实现基本<a class=性能测试的配置页面及负载配置选项截图" />

【图 15.1 Postman 实现基本性能测试的配置页面及负载配置选项截图】

目前共支持四类负载配置类型:

类型特点适用场景
Fixed(固定负载)模拟恒定不变的负载,用户数量或请求速率在整个测试期间保持不变适用于评估系统在稳定负载下的表现
Ramp up(逐步增加负载)负载从低到高逐步增加,模拟用户或请求逐渐增多的场景适用于测试系统在负载逐步增加时的响应和稳定性
Spike(突发负载)短时间内负载急剧增加,模拟突发的高流量场景适用于测试系统在突发高负载下的表现和恢复能力
Peak(峰值负载)负载在短时间内达到峰值,模拟系统在高峰期的表现适用于评估系统在最大负载下的性能和稳定性

切换每个类型,下方都会显示该类型的可视化配置图,表征虚拟用户数(Virtual Users,即 VUs)随时间的变化趋势:

图 15.2 Fixed 型负载配置示意图

【图 15.2 Fixed 型负载配置示意图】

图 15.3 Ramp up 型负载配置示意图

【图 15.3 Ramp up 型负载配置示意图】

图 15.4 Spike 型负载配置示意图

【图 15.4 Spike 型负载配置示意图】

图 15.5 Peak 型负载配置示意图

【图 15.5 Peak 型负载配置示意图】

由于在 PostmanCollection Runner 进行性能测试,只能模拟最多 100 个虚拟用户节点发起请求,不仅测试规模有限,性能参数的监控也不够全面,仅供了解即可。

3 Postman 性能测试实战

总思路:以 GitPod 在线演示项目 ToDo List App 为基础,利用 Collection Runner 进行基础的性能测试

3.1 Fixed 型负载下的性能测试

新建测试集合 Performance Testing,并添加示例请求 Get task list,请求接口 GET {{url}}/tasks

模拟 10 个虚拟用户节点、1 分钟内的性能测试

图 15.6 Fixed 型负载下模拟 10 个虚拟用户 1 分钟内的<a class=性能测试配置页截图" />

【图 15.6 Fixed 型负载下模拟 10 个虚拟用户 1 分钟内的性能测试配置页截图】

运行结果如下:

图 15.7 <a class=性能测试进行中的实时监控情况截图" />

【图 15.7 性能测试进行中的实时监控情况截图】

图 15.8 <a class=性能测试完成后的结果展示页截图" />

【图 15.8 性能测试完成后的结果展示页截图】

从测试集合的运行统计表中还可以看到更多性能指标:

图 15.9 从测试集合的运行统计栏中还可以看到更多性能指标数据

【图 15.9 从测试集合的运行统计栏中还可以看到更多性能指标数据】

其余负载类型均可如法炮制。

3.2 基于数据驱动的 Postman 接口性能测试

本例演示上传 CSV 数据文件进行 Fixed 型负载性能测试,目标接口为 ToDo List App 项目的 PUT /tasks/1 修改接口。

首先从浏览器登录 user1user1/12345),并手动添加一则待办事项:

图 15.10 先从页面登录 user1,并新增一则待办事项

【图 15.10 先从页面登录 user1,并新增一则待办事项】

然后创建一个控制 status 状态的 CSV 文件 status.csv,内容如下(可用 Excel 另存为 csv 格式):

Status
Draft
In Progress
Complete

同时设置 PUT 请求的请求体为,注意变量名 Status 要与 CSV 文件的字段列名称保持一致:

{"description": "Do Something Great","status": "{{Status}}"
}

上传该 CSV 文件,此时会立即弹出一个临时窗口,选择随机插值后确认:

图 15.11 上传 CSV 数据文件时,在自动弹出的窗口中设置插值方式为随机插值

【图 15.11 上传 CSV 数据文件时,在自动弹出的窗口中设置插值方式为随机插值】

最后检查其他配置,再次运行 Collection Runner

图 15.12 再次确认<a class=性能测试各项配置" />

【图 15.12 再次确认性能测试各项配置】

运行结果如下:

图 15.13 基于数据驱动的<a class=性能测试实时运行界面截图" />

【图 15.13 基于数据驱动的性能测试实时运行界面截图】

图 15.14 基于数据驱动的<a class=性能测试实时 GitPod 后端运行界面截图" />

【图 15.14 基于数据驱动的性能测试实时 GitPod 后端运行界面截图】

图 15.15 基于数据驱动的<a class=性能测试运行结束后的界面截图" />

【图 15.15 基于数据驱动的性能测试运行结束后的界面截图】

此外,还可以在某个运行详情页与其他性能测试记录进行对比,并结合统计图中的选筛条件,实现更多性能指标的综合对比:

图 15.16 不同<a class=性能测试的运行指标对比效果图" />

【图 15.16 不同性能测试的运行指标对比效果图】

4 性能测试的注意事项

何时进行:尽量在开发周期的早期阶段进行。

性能测试中各个基准指标的确定

  • 单一负载:尽量设计得简单可靠;
  • 复杂负载:除了考察可以接受的响应速度边界,还应考虑时间随负载的变化趋势。

可重复性的考虑

性能测试对可重复性的要求相对较低,但这并不意味着可重复性不重要,而是要在有限条件下尽可能确保可重复性:

  • 尽可能确保 测试环境的标准化:相同的底层硬件、相同数量的内核环境、内存配置、相同的 Docker 容器配置等等,尽可能降低性能测试的噪音;
  • 认真考虑 初始数据性能测试的影响,尽量保持一致;
  • 一致的性能测试数据清理流程;
  • 建议不要总是自动删除数据,而是根据实际情况决定是否有必要保留(既有数据也可能会有助于后续调试);
  • 系统的冷启动问题:初始阶段可能性能尚不稳定;
  • 推荐制定一套明确的操作步骤文档;
  • 各性能指标的确认需要多方参与,综合考虑,避免纸上谈兵,闭门造车。

http://www.ppmy.cn/server/166647.html

相关文章

JMeter通过BeanShell如何对CSV文件的指定列追加数据

在 JMeter 中实现向 CSV 文件的 指定列追加数据&#xff0c;需根据场景选择不同方法。以下是两种典型场景的实现方案&#xff1a; 场景 1&#xff1a;生成新行时填充指定列的数据 若每次请求生成一行新数据&#xff0c;并在特定列填充动态值&#xff08;如第三列&#xff09;&…

2025年02月05日Github流行趋势

项目名称&#xff1a;OCRmyPDF 项目地址url&#xff1a;https://github.com/ocrmypdf/OCRmyPDF项目语言&#xff1a;Python历史star数&#xff1a;15872今日star数&#xff1a;157项目维护者&#xff1a;jbarlow83, fritz-hh, apps/dependabot, mawi12345, mara004项目简介&…

网络安全技术架构 网络安全结构体系图

1.基础研究 1.1密码理论 1.2数据加密 1.3消息摘要 1.4数字签名 1.5密钥管理 信息隐藏 2.应用研究 2.1安全技术 2.2防火墙技术 2.3入侵检测 2.4漏洞扫描 2.5防病毒技术 3.管理研究 3.1安全策略 3.2安全标准 3.3安…

鸿蒙音视频播放器:libwlmedia

libwlmedia 跨平台播放器wlmedia现在已经支持了鸿蒙(Harmony)平台了&#xff0c;SDK插件地址&#xff1a;libwlmedia 一、接入SDK 1.1 导入SDK ohpm i ywl5320/libwlmedia1.2 添加权限&#xff08;可选&#xff09; 如果需要播放网络视频&#xff0c;需要添加网络权限 #m…

蓝桥杯 Java 之输入输出

一、输入输出方式&#xff1a;Scanner vs BufferedReader Scanner类 简介&#xff1a;Scanner 是 Java 中一个非常方便的用于读取用户输入的类&#xff0c;它可以从多种输入源&#xff08;如标准输入、文件等&#xff09;读取基本数据类型和字符串。 1. Scanner的细节与使用…

pgBackRest 是专为 PostgreSQL 设计的开源备份与恢复工具,以其高性能、可靠性和灵活性著称

pgBackRest 是专为 PostgreSQL 设计的开源备份与恢复工具&#xff0c;以其高性能、可靠性和灵活性著称。它支持 全量备份、增量备份、并行备份/恢复 和 加密 等特性&#xff0c;适用于大规模数据库和关键业务场景。以下是其核心功能及操作指南&#xff1a; 一、pgBackRest 核心…

清影2.0(AI视频生成)技术浅析(一)

清影2.0是由某科技公司推出的一款先进的AI视频生成平台,旨在通过人工智能技术实现从文本到视频的自动化创作。该平台结合了自然语言处理(NLP)、计算机视觉(CV)、音频处理以及深度学习等多个领域的最新技术,能够根据用户输入的文本描述自动生成高质量的视频内容。 1.平台…

简述MySQL主从复制原理及其工作过程,配置一主两从并验证

主从原理&#xff1a;MySQL主从同步是一种数据库复制技术&#xff0c;它通过将主服务器上的数据进行更改复制到一个或多个从服务器&#xff0c;实现数据的自动同步。 主从同步的核心原理是将主服务器上的二进制日志复制到从服务器&#xff0c;并且在从服务器上执行这些日志的操…