性能测试技术笔记(三):如何设计一个压测平台

简介: 对于压测平台,或者说各种测试平台,其实很多同学有个误区就是:平台各种高大上牛逼,但往往忽略了开发和维护以及学习使用平台本身的成本。

前面两篇笔记介绍了如何快速上手压测项目以及压测前准备测试环境和测试数据的一些方法。


这篇文章,我想分享下关于压测平台功能设计和技术实现方案的一些技术笔记内容,内容主要来源于两方面:


  • 18年我所在性能团队使用的压测平台技术实现细节;
  • 20年后我带稳定性团队时我们开发的全链路压测平台的功能设计和技术方案;


为什么需要压测平台?


从实际工作场景出发,如果只有一两个人做性能测试工作,那其实没必要开发专门的压测平台,原因如下:


  • 成本问题:开发压测平台,前期需要投入至少1-2个专门的人力,且需要长期维护;
  • 效率问题:人数少,基本相当于压测任务并不太多,脚本管理数据管理这些可以通过本地上传到服务器,服务器只需要按照业务域和压测节点,建立对应的文件目录,然后有个crontab的定时任务来清理即可;
  • 协作问题:人数少其实不太需要平台来解决规范和流程问题,协作的事情几句话口头就可以沟通解决;


对于压测平台,或者说各种测试平台,其实很多同学有个误区就是:平台各种高大上牛逼,但往往忽略了开发和维护以及学习使用平台本身的成本。


测试平台的目的是:通过平台提供标准化操作,将不同个体差异通过流程化的方式约束起来,减少重复造轮子和轮子之间差异导致的排查和解决问题的成本,进一步提高人效


毕竟工作最终是结果导向的,如果没有更高效的解决问题,那平台最终会成为沉没成本


假设现在你想拥有一个压测平台,那我个人觉得最起码需要满足如下几个条件:


  1. 业务线多,版本迭代快(需求驱动);
  2. 测试团队个体间的技术差异比较大(技术驱动);
  3. 性能需求较多,线上稳定性问题频发(问题驱动);
  4. 技术团队达到一定规模,做压测的人比较多(效率驱动);


压测平台功能设计思路


聊完了关于压测平台是否必须以及要解决的问题,这部分聊聊一个可用的压测平台要满足哪些条件。


  1. 简单易用:平台学习和使用成本低,操作简单快捷;
  2. 数据持久化:测试脚本&测试数据&测试结果持久化,便于追溯历史记录;
  3. 维护成本低:满足开箱即用,和外部系统可以交互,出问题也有高效的技术支持;
  4. 支持多人协同:可以满足不同团队的人使用,快速开展压测工作且不会交叉影响;
  5. 便于配置管理:对压测集群、压测组件和一些配置项的管理便捷高效,不用手敲太多命令;
  6. 完善的施压支持:支持一定的高并发能力,压测集群可扩展,支持多协议和基本的自定义扩展能力;


看完上述条件,我们对压测平台的功能模块,就有了比较明确的要求。


  1. 用例管理:一个压测项目可以创建多个压测任务,任务=用例,用例包含压测脚本、压测数据和插件;
  2. 压测执行:支持手动和定时执行压测,可以配置运行参数、可以选择多个压测节点、支持同时运行多个压测任务;
  3. 实时监控:压测过程中实时展示TPS、RT、请求数、错误率等核心指标,并支持按时间段选择和计算;
  4. 压测结果:压测结束后整个任务的压测结果可以进行详细的展示,比如TPS、ART、90/95/99RT、成功/失败请求数、错误日志等;
  5. 配置管理:比如压测节点参数变更、绑定host、插件上传更新等;
  6. 扩展功能:比如支持mock、openAPI、造数工具、三方库兼容等;


看完了上面的条件和功能模块要求,那么一个基本的压测平台,要具备哪些具体的功能呢?请看下图:


640.png

PS:此图仅供参考,并不代表要完全有这些功能,根据自己的具体情况设定。


压测平台技术实现方案


接下来聊聊压测平台部分功能的技术实现方案。


压测平台的技术架构其实关键字搜索已经很多了,这里我也不想多费笔墨,在其他人的基础上微创新。我想分享一些具体功能模块的技术实现方案,供大家参考。


mock功能


640.png


日志采样功能

640.png


PS该功能是基于jmeter为压测工具实现的,仅供参考。


如上就是我关于压测平台的一些工作实践笔记和个人思考。


下篇文章,我会聊聊关于质量度量的新看法,敬请期待。

相关文章
|
2月前
|
关系型数据库 MySQL 测试技术
【分享】AgileTC测试用例管理平台使用分享
AgileTC 是一个脑图样式测试用例管理平台,支持用例设计、执行与团队协作,帮助测试人员高效管理测试流程。
250 116
【分享】AgileTC测试用例管理平台使用分享
|
2月前
|
人工智能 数据可视化 测试技术
Postman 性能测试教程:快速上手 API 压测
本文介绍API上线后因高频调用导致服务器告警,通过Postman与Apifox进行压力测试排查性能瓶颈。对比两款工具在批量请求、断言验证、可视化报告等方面的优劣,探讨API性能优化策略及行业未来发展方向。
Postman 性能测试教程:快速上手 API 压测
|
2月前
|
人工智能 数据可视化 测试技术
AI测试平台自动遍历:低代码也能玩转全链路测试
AI测试平台的自动遍历功能,通过低代码配置实现Web和App的自动化测试。用户只需提供入口链接或安装包及简单配置,即可自动完成页面结构识别、操作验证,并生成可视化报告,大幅提升测试效率,特别适用于高频迭代项目。
|
2月前
|
人工智能 测试技术 调度
写用例写到怀疑人生?AI 智能测试平台帮你一键生成!
霍格沃兹测试开发学社推出AI智能测试用例生成功能,结合需求文档一键生成高质量测试用例,大幅提升效率,减少重复劳动。支持自定义提示词、多文档分析与批量管理,助力测试人员高效完成测试设计,释放更多时间投入核心分析工作。平台已开放内测,欢迎体验!
|
2月前
|
人工智能 测试技术 项目管理
测试不再碎片化:AI智能体平台「项目资料套件」功能上线!
在实际项目中,需求文档分散、整理费时、测试遗漏等问题常困扰测试工作。霍格沃兹推出AI智能体测试平台全新功能——项目资料套件,可将多个关联文档打包管理,并一键生成测试用例,提升测试完整性与效率。支持套件创建、文档关联、编辑删除及用例生成,适用于复杂项目、版本迭代等场景,助力实现智能化测试协作,让测试更高效、更专业。
|
3月前
|
Web App开发 人工智能 JavaScript
主流自动化测试框架的技术解析与实战指南
本内容深入解析主流测试框架Playwright、Selenium与Cypress的核心架构与适用场景,对比其在SPA测试、CI/CD、跨浏览器兼容性等方面的表现。同时探讨Playwright在AI增强测试、录制回放、企业部署等领域的实战优势,以及Selenium在老旧系统和IE兼容性中的坚守场景。结合六大典型场景,提供技术选型决策指南,并展望AI赋能下的未来测试体系。
|
3月前
|
存储 人工智能 算法
AI测试平台实战:深入解析自动化评分和多模型对比评测
在AI技术迅猛发展的今天,测试工程师面临着如何高效评估大模型性能的全新挑战。本文将深入探讨AI测试平台中自动化评分与多模型对比评测的关键技术与实践方法,为测试工程师提供可落地的解决方案。
|
5月前
|
存储 测试技术 虚拟化
VMmark 4.0.3 - 虚拟化平台基准测试
VMmark 4.0.3 - 虚拟化平台基准测试
167 0
VMmark 4.0.3 - 虚拟化平台基准测试
|
2月前
|
人工智能 Java 测试技术
单元测试覆盖率的自动控制技术
Jacoco是Java程序覆盖率工具,可以在pom.xml通过配置来自动控制程序的覆盖率
79 5
|
2月前
|
测试技术 UED 开发者
性能测试报告-用于项目的性能验证、性能调优、发现性能缺陷等应用场景
性能测试报告用于评估系统性能、稳定性和安全性,涵盖测试环境、方法、指标分析及缺陷优化建议,是保障软件质量与用户体验的关键文档。