如何分析并设计性能测试场景

本文涉及的产品
性能测试 PTS,5000VUM额度
简介: 以上就是关于性能需求分析以及场景设计的内容,文中举的例子仅供参考,在实际的工作中,需要学会灵活变通。

640.png


前几天写了一篇文章《如何设计自动化测试case,里面聊到了为什么要设计case:


  1. 便于业务活动开展
  2. 确保业务场景覆盖
  3. 质量度量和质量内建


其实这几点原因,在性能测试活动中同样适用。


这篇文章,我想聊聊基于性能测试需求分析的压测场景设计的话题。


如何理解性能测试场景?


性能测试场景,其实和功能测试没什么区别,只是侧重点不同。


我们在功能测试中经常用到的等价类边界值等分析和设计测试case的方法,目的是为了尽可能的覆盖业务场景,避免遗漏导致的功能逻辑缺失或者未达到预期。


而在性能测试中,基于性能需求分析和设计性能测试场景,侧重的是基于业务场景的请求/流量配比,以及测试数据准备。这实际上就是我在前面的文章《全链路压测(8):构建三大模型》中提到的性能测试三大模型:


  1. 业务场景模型
  2. 请求流量模型
  3. 测试数据模型


如何设计性能测试场景?


假设现在我们要开展一次性能测试,需求背景及描述如下:


需求背景:互联网电商平台;

需求描述:验证订单相关的业务及订单服务的性能;

预期目标:订单服务可以支撑日常线上业务稳定运行;

预期指标:服务级别TPS>200,P0接口99RT<100ms,线上应用CPU%<=40%;


这个时候,如何进行需求分析和测试场景设计呢?


需求分析


1.要验证订单服务的性能;

a.需要混合场景验证;

b.要考虑请求流量配比;

2.P0接口的99RT<100ms;

a.需要梳理订单服务P0接口;

b.检查相关监控工具是否接入;


场景设计


假设订单服务有4个P0接口;

分别是创建订单/确认订单/订单列表/订单详情;

各自请求流量占比分别是35%/30%/20%/15%(这里忽略其他占比较小的接口,实际工作中要考虑真实占比);


那么压测场景设计如下:


编号

场景名称

场景类型

压测方式

压测目的

备注说明

1

创建订单

单机单接口

梯度递增

寻找性能拐点,发现性能瓶颈

可能需要多次压测验证


2

确认订单

单机单接口

梯度递增

寻找性能拐点,发现性能瓶颈

3

订单列表

单机单接口

梯度递增

寻找性能拐点,发现性能瓶颈

4

订单详情

单机单接口

梯度递增

寻找性能拐点,发现性能瓶颈

5

混合场景

单机服务级

(流量配比)

梯度递增

寻找性能拐点,发现性能瓶颈

6

稳定并发压测

验证预期范围内的性能是否达标

多次调整并发,直至性能达标

7

稳定性测试(>12h)

验证服务长时间运行的稳定性

以最后一次稳定并发压测数值压测


如上所示,大概需要设计七个场景,分别验证接口级别和服务级别的性能。


问题:为什么不直接压测混合场景?


答案:因为一个服务有多个接口,每个接口都可能存在影响性能的因素,通过单接口压测,快速排查解决存在性能问题的因素,这样可以减少直接混合场景压测的性能问题定位分析和优化验证难度。


数据准备


数据准备取决于被测的业务场景,以上面的需求为例,准备测试数据时要注意两方面:


业务逻辑


  1. 订单商品库存是否充足;
  2. 下单用户是否有可用优惠券;
  3. 下单用户优惠券是否可叠加;
  4. 订单商品是否参与营销活动;
  5. 下单用户是否需要登录状态检查;
  6. 订单商品优惠券与营销活动是否可叠加;


数据量级


  1. 下单用户数量级;
  2. 用户登录态token有效期;
  3. 商品库存数量是否足够多次使用;
  4. 用户优惠券是否足够(需考虑优惠券核销和恢复);
  5. 营销活动创建以及优惠券&商品和营销活动的关联配置;


完成上述步骤,接下来才是后续的动作。后续的压测准备事项大概包括如下几项:


  1. 环境检查;
  2. DDL同步;
  3. 被测服务分支发布;
  4. 脚本开发及联调通过;


以上就是关于性能需求分析以及场景设计的内容,文中举的例子仅供参考,在实际的工作中,需要学会灵活变通。


当然,经验比较丰富的同学场景设计其实可做可不做,流程只是提供一种工程实践的指导思路,并不需要完全照搬。

相关实践学习
通过性能测试PTS对云服务器ECS进行规格选择与性能压测
本文为您介绍如何利用性能测试PTS对云服务器ECS进行规格选择与性能压测。
相关文章
|
2月前
|
缓存 监控 算法
软件测试中的性能瓶颈分析与优化策略
【10月更文挑战第6天】 性能测试是确保软件系统在高负载条件下稳定运行的重要手段。本文将深入探讨性能测试的常见瓶颈,包括硬件资源、网络延迟和代码效率等问题。通过具体案例分析,我们将展示如何识别并解决这些问题,从而提升软件的整体性能。最后,文章还将分享一些实用的性能优化技巧,帮助读者在日常开发和测试中更好地应对性能挑战。
120 3
|
3月前
|
监控 测试技术 持续交付
软件测试中的性能瓶颈分析与优化策略
性能瓶颈,如同潜伏于软件深处的隐形障碍,悄然阻碍着系统的流畅运行。本文旨在揭示这些瓶颈的形成机理,剖析其背后的复杂成因,并汇聚一系列针对性的优化策略,为软件开发者提供一套系统性的解决方案。
61 5
|
26天前
|
监控 算法 Java
jvm-48-java 变更导致压测应用性能下降,如何分析定位原因?
【11月更文挑战第17天】当JVM相关变更导致压测应用性能下降时,可通过检查变更内容(如JVM参数、Java版本、代码变更)、收集性能监控数据(使用JVM监控工具、应用性能监控工具、系统资源监控)、分析垃圾回收情况(GC日志分析、内存泄漏检查)、分析线程和锁(线程状态分析、锁竞争分析)及分析代码执行路径(使用代码性能分析工具、代码审查)等步骤来定位和解决问题。
|
26天前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
57 1
|
1月前
|
JavaScript 安全 编译器
TypeScript 与 Jest 测试框架的结合使用,从 TypeScript 的测试需求出发,介绍了 Jest 的特点及其与 TypeScript 结合的优势,详细讲解了基本测试步骤、常见测试场景及异步操作测试方法
本文深入探讨了 TypeScript 与 Jest 测试框架的结合使用,从 TypeScript 的测试需求出发,介绍了 Jest 的特点及其与 TypeScript 结合的优势,详细讲解了基本测试步骤、常见测试场景及异步操作测试方法,并通过实际案例展示了其在项目中的应用效果,旨在提升代码质量和开发效率。
42 6
|
1月前
|
网络协议 关系型数据库 应用服务中间件
【项目场景】请求数据时测试环境比生产环境多花了1秒是怎么回事?
这是一位粉丝(谢同学)给V哥的留言,描述了他在优化系统查询时遇到的问题:测试环境优化达标,但生产环境响应时间多出1秒。通过抓包分析,发现MySQL请求和响应之间存在500毫秒的延迟,怀疑是网络传输开销。V哥给出了以下优化建议:
|
2月前
|
缓存 监控 测试技术
软件测试中的性能瓶颈分析与优化策略
本文深入探讨了在软件测试过程中,如何有效地识别和解决性能瓶颈问题。通过对性能瓶颈的定义、分类以及常见原因的分析,结合实际案例,提出了一系列针对性的优化策略和方法。这些策略旨在帮助测试人员和开发人员提高软件的性能表现,确保软件在高负载条件下依然能够稳定运行。
|
3月前
|
设计模式 SQL 安全
PHP中的设计模式:单例模式的深入探索与实践在PHP的编程实践中,设计模式是解决常见软件设计问题的最佳实践。单例模式作为设计模式中的一种,确保一个类只有一个实例,并提供全局访问点,广泛应用于配置管理、日志记录和测试框架等场景。本文将深入探讨单例模式的原理、实现方式及其在PHP中的应用,帮助开发者更好地理解和运用这一设计模式。
在PHP开发中,单例模式通过确保类仅有一个实例并提供一个全局访问点,有效管理和访问共享资源。本文详细介绍了单例模式的概念、PHP实现方式及应用场景,并通过具体代码示例展示如何在PHP中实现单例模式以及如何在实际项目中正确使用它来优化代码结构和性能。
56 2
|
3月前
|
测试技术 持续交付 UED
软件测试的艺术与科学:平衡创新与质量的探索在软件开发的波澜壮阔中,软件测试如同灯塔,指引着产品质量的方向。本文旨在深入探讨软件测试的核心价值,通过分析其在现代软件工程中的应用,揭示其背后的艺术性与科学性,并探讨如何在追求技术创新的同时确保产品的高质量标准。
软件测试不仅仅是技术活动,它融合了创造力和方法论,是软件开发过程中不可或缺的一环。本文首先概述了软件测试的重要性及其在项目生命周期中的角色,随后详细讨论了测试用例设计的创新方法、自动化测试的策略与挑战,以及如何通过持续集成/持续部署(CI/CD)流程优化产品质量。最后,文章强调了团队间沟通在确保测试有效性中的关键作用,并通过案例分析展示了这些原则在实践中的应用。
96 1
|
3月前
|
监控 算法 测试技术
软件测试中的性能瓶颈分析与优化策略
本文旨在深入探讨软件测试过程中性能瓶颈的识别与优化方法。通过对性能瓶颈的概念、分类及其成因进行分析,结合实际案例,提出一套系统的性能瓶颈诊断流程和针对性的优化策略。文章首先概述了性能瓶颈的基本特征,随后详细介绍了内存泄漏、资源竞争、算法效率低下等常见瓶颈类型,并阐述了如何通过代码审查、性能监测工具以及负载测试等手段有效定位问题。最后,结合最佳实践,讨论了代码级优化、系统配置调整、架构改进等多方面的解决措施,旨在为软件开发和测试人员提供实用的性能优化指导。
94 4