做好性能测试计划的4个步骤!全都是精华!【建议收藏】

如何做好一次性能测试计划呢?对于性能测试新手来说,也许你非常熟悉Jmeter的使用,也许你清楚的了解每一个系统参数代表的意义,但是想要完成好一次性能测试任务,并不仅仅是简单的写脚本,加压力,再拿到响应结果和监控数据这么简单。有哪些关键因素需要好好考虑呢?以下是我个人总结的一些关键点,供大家参考。

性能测试其实是一个非常庞大的领域,涉及到很多知识和专业技能。而针对不同的被测系统或被测产品,又有不同的测试方式和侧重点。此文谈及的性能测试是针对互联网后端服务的性能测试。

在业务线上做性能测试,首先以了解业务背景为前提条件,在此基础上,去做一个尽可能完备的测试计划,设计出关键且有效的测试场景,用最少的测试执行来回答被测系统性能如何这个问题。我总结了一些个人在做性能测试计划方面的心得和体会,希望能够对大家在做性能测试计划的时候有所帮助。


在做性能测试计划的时候,我们首先需要充分思考这几个问题:

  1. 我们需要知道系统的哪些性能情况?
  2. 我们要采用哪种类型的性能测试,通过哪些测试场景来评估系统的性能情况?
  3. 按照我们制定的性能测试计划,最终拿到的测试结果能不能支持推断出系统性能是否符合业务目标的结论?

一、明确目标

要回答第一个问题,最好的切入点是了解业务目标是什么。

  1. 业务目标的确定:在做性能测试计划前,我们应该向项目组核心成员去了解业务情况,询问项目经理、运营、产品、技术负责人,预期的业务量是多少?未来规划的提升量是多少?在哪些方面有特殊的业务要求,比如哪些场景对响应时间有强要求,是否会有促销手段可能导致线上出现秒杀情况等等。
  2. 性能风险的推测:条件允许的情况下,我们还可以向项目组的每个参与者了解情况:你最担心系统出现的性能问题是什么?为什么会有这样的担心?有时候项目的核心成员并不清楚系统设计的细节,而那些被忽略的细节又常常出其不意的在线上带给我们麻烦。
  3. 明确性能测试目标:整理自己对业务的理解,梳理收集到的业务目标和问题,将业务化的目标转化成明确的性能测试目标。

二、选取方法

关于第二个问题,在我们已知性能测试目标的情况下,应该采用哪种类型的性能测试手段呢?我总结了一下几种主要的性能测试的特点,如下表所示:

在已知这些不同类型性能测试的特点后,我们就能更好的做出选择,采用恰当的方式更高效的达到测试目的。例如:

  • 如果业务目标关心用户操作后多快能收到响应,那么我们会选性能测试(Performance Test)来作为主要测试方法。
  • 如果想要知道用户抢购某商品时出现“挤爆了”提示后会不会影响其他业务,以及出现问题后多久能恢复正常,那么我们可以选择压力测试(Stress Test)
  • 如果想要知道业务不断扩张,用户群体不断增长的情况下,最应该先做哪方面的系统优化准备,那么我们会选择进行容量测试(Capacity Test)。

当然,大多实践的时候,你会发现单一的测试方式并不能回答我们关于被测系统或被测应用的全部问题,我们需要采用几种测试方法共同完成一次性能测试任务。

现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:110685036【暗号:csdn999】

三、减小差异

第三个问题,测试结果能不能支持推断线上系统性能是否符合业务目标?这个问题并不是在拿到最终测试结果的时候才应该去思考的。这个问题的思考时机应当前置,并且贯穿整个性能测试计划设计以及测试执行过程中。为了让我们的测试结果更具有准确性和权威性,在做性能测试计划的时候,应该从两方面考虑:

  1. 测试环境和生产环境尽可能的保持一致,包括硬件条件和软件配置都尽可能一致,对于达不到一致的方面,要分析差异及存在的影响。
  2. 测试场景中模拟的用户行为,要尽可能贴近真实用户的行为习惯。在设计压测场景时,不能纯粹靠想象去预估用户行为和各个行为的用户比例,我们应当结合已监控到的真实用户行为,合理建立压测模型。在这两点基础之上,得出压测数据后,再结合其他因素来预估线上性能情况。

四、产出计划

想清楚上述问题后,我们再来填充我们的性能测试计划。个人认为一个全面的测试计划,应该包含以下几个部分:

1)性能测试目的

像前文已经提到过的,我们应该明确性能测试的目的,了解被测业务特点和业务目标,并将业务目标转化为明确的性能指标。为了更好的帮助我们理解被测系统,画出被测系统架构图是很必要的,在整个系统架构图中,确定被测系统范围,集中精力到需要关注的性能表现上。

2)性能测试环境

  1. 了解清楚生产环境的各种配置,明确测试环境需要的硬件、软件条件。
  2. 思考是否需要借助其他辅助工具来完成性能测试任务
  3. 充分对比生产环境和测试环境差异,差异说明可以为后续分析和推测线上性能情况提供参考信息。

3)测试场景设计

  1. 了解业务后,选择关键链路,并对不同链路设置优先级
  2. 根据测试场景,做辅助测试数据准备
  3. 监控数据项列举
  4. 测试脚本准备方案和验证方案
  5. 测试场景列表,包含关键项:场景名称、场景描述、并发用户数、用户分布、持续时间等

4)测试执行计划

  1. 性能测试准入条件
  2. 测试执行schedule
  3. 测试执行策略,例如单个场景执行三次,统计平均值
  4. 测试执行完成条件

5)性能测试交付内容

  1. 性能测试结果数据
  2. 性能测试结论,是否达到预期指标,是否能支持业务需求
  3. 性能优化建议

6)风险说明

  1. 排期风险
  2. 技术风险
  3. 资源风险

以上是基于个人的有限性能测试经验总结出的几个关键点,包括做性能测试设计时应该注重的几个关键问题,同时给出了一个性能测试计划里应包含的关键部分。具体实践中,涉及到的问题可能还有很多,设计方案还需要考虑方方面面的因素,但是这些关键要素能帮我们快速思考清楚如何准备当前的性能测试任务。性能测试领域还有很多知识待挖掘,许多经验待总结和分享,希望我的这篇总结对大家能有所帮助。

END今天的分享就到此结束了,点赞关注不迷路~

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

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

相关文章

【Seata源码学习 】篇三 TM开启全局事务的过程

【Seata源码学习 】篇三 TM开启全局事务的过程 TM发送 单个或批量 消息 以发送GlobalBeginRequest消息为例 TM在执行拦截器链路前将向TC发送GlobalBeginRequest 消息 io.seata.tm.api.DefaultGlobalTransaction#begin(int, java.lang.String) Overridepublic String begin(…

使用iframe 发现样式错位的解决办法

原理就是默认隐藏 点击的时候(或者需要的时候)展示出来 方法二 宽高为0

nacos网关

目录 拉取docker镜像 环境配置 网关搭建架构 wemedia-gateway网关配置 依赖 启动类配置 网关yml配置 nacos配置中心配置网关 wdmedia服务配置 依赖 启动类配置 yml配置 nacos配置 nacos中的配置共享 nacos配置 wmedia模块中yml的配置 参考:https://blog.csdn.net/…

springBoot中starter

springBoot项目中引入starter 项目引入xxljob&#xff0c;仅需要导入对应的starter包&#xff0c;即可进行快速开发 <dependency><groupId>com.ydl</groupId><artifactId>xxl-job-spring-boot-starter</artifactId><version>0.0.1-SNAPS…

深度学习知识点

深度学习过程 data [] for i,d in enumerate(data):image,label d image,label image.cuda(),label.cuda()img net(image)optimizer.zero_grad()#需要将梯度信息清零&#xff0c;因为梯度计算是按照batch分批次计算的&#xff0c;如果这一批batch没清零&#xff0c;会影响…

P1141 01迷宫(dfs+染色联通块)

染色联通块&#xff1a; 一个格联通的所有格 每个对应的最大可联通格子的个数均相同 分析&#xff1a; 1.只需要计算每个块里的元素个数 2.元素标记对应某个块 3.查找元素时&#xff1a; 由 &#xff08;1&#xff09;元素坐标-> &#xff08;2&#xff09;查找…

庖丁解牛:NIO核心概念与机制详解 07 _ 字符集

文章目录 Pre概述编码/解码处理文本的正确方式示例程序Code Pre 庖丁解牛&#xff1a;NIO核心概念与机制详解 01 庖丁解牛&#xff1a;NIO核心概念与机制详解 02 _ 缓冲区的细节实现 庖丁解牛&#xff1a;NIO核心概念与机制详解 03 _ 缓冲区分配、包装和分片 庖丁解牛&…

验证回文串

题目链接 验证回文串 题目描述 注意点 1 < s.length < 200000s 仅由可打印的 ASCII 字符组成将所有大写字符转换为小写字符忽略所有非字母数字字符 解答思路 首先将大写字母转为小写字母&#xff0c;再双指针分别从首尾判断对应位置的字符是否相同&#xff0c;注意当…

基于springboot实现应急救援物资管理系统项目【项目源码】计算机毕业设计

基于springboot实现应急救援物资管理系统演示 JAVA简介 JavaScript是一种网络脚本语言&#xff0c;广泛运用于web应用开发&#xff0c;可以用来添加网页的格式动态效果&#xff0c;该语言不用进行预编译就直接运行&#xff0c;可以直接嵌入HTML语言中&#xff0c;写成js语言&a…

「MobileNet V3」70 个犬种的图片分类

✅作者简介&#xff1a;人工智能专业本科在读&#xff0c;喜欢计算机与编程&#xff0c;写博客记录自己的学习历程。 &#x1f34e;个人主页&#xff1a;小嗷犬的个人主页 &#x1f34a;个人网站&#xff1a;小嗷犬的技术小站 &#x1f96d;个人信条&#xff1a;为天地立心&…

每日一题 2216. 美化数组的最少删除数(中等,贪心)

贪心&#xff0c;一开始可能会觉得如果删除前面一个相等的元素时&#xff0c;会导致后面的元素前移&#xff0c;造成产生更多的相等的元素对的情况但是在遍历过程中至少要在相等元素对中删除一个&#xff0c;也可以同时删除两个使得后面的元素奇偶关系不变&#xff0c;但是显然…

【C++上层应用】5. 文件和流

文章目录 【 1. 打开文件 】1.1 open 函数1.2 open 多种模式的结合使用 【 2. 关闭文件 】【 3. 写入 & 读取文件 】【 4. 文件位置指针 】 和 iostream 库中的 cin 标准输入流和 cout 标准输出流类似&#xff0c;C中另一个库 fstream 也存在文件的读取流和标准写入流。fst…

可视化大屏时代的到来:智慧城市管理的新思路

随着科技的不断发展&#xff0c;智能芯片作为一种新型的电子元件&#xff0c;被广泛应用于各个领域&#xff0c;其中智慧芯片可视化大屏是一种重要的应用形式。 一、智慧芯片可视化大屏的优势 智慧芯片可视化大屏是一种将智能芯片与大屏幕显示技术相结合的产品&#xff0c;山海…

从算法到应用:直播美颜滤镜SDK的全面解读与评测

直播美颜滤镜SDK技术逐渐成为直播平台不可或缺的一环。本文将对直播美颜滤镜SDK进行全面解读&#xff0c;深入探讨其算法原理和应用效果&#xff0c;并通过评测分析展现其在直播领域的实际价值。 一、算法原理解读 直播美颜滤镜的背后是复杂而精密的算法&#xff0c;旨在提升…

React结合antd5实现整个表格编辑

通过react hooks 结合antd的table实现整个表格新增编辑。 引入组件依赖 import React, { useState } from react; import { Table, InputNumber, Button, Space, Input } from antd;定义数据 const originData [{ key: 1, name: 白银会员, value: 0, equity: 0, reward: 0…

头歌 MySQL数据库 - 初识MySQL

本章内容是为了完成老师布置的作业&#xff0c;同时也是为了以后考试的时候方便复习。 数据库部分一条一条的写&#xff0c;可鼠标手动粘贴&#xff0c;除特定命令外未分大小写。 第1关&#xff1a;创建数据库 在操作数据库之前&#xff0c;需要连接它&#xff0c;输入命令&a…

怎么让NetCore接口支持Json参数

项目&#xff1a;NetCore Web API 接口支持Json参数需要安装Newtonsoft.Json.Linq和Microsoft.AspNetCore.Mvc.NewtonsoftJson Program代码 //支持json需要安装Microsoft.AspNetCore.Mvc.NewtonsoftJson using Newtonsoft.Json.Serialization;var builder WebApplication.Cr…

【C/PTA】函数专项练习(一)

本文结合PTA专项练习带领读者掌握函数&#xff0c;刷题为主注释为辅&#xff0c;在代码中理解思路&#xff0c;其它不做过多叙述。 目录 6-1 输出星期名6-2 三整数最大值6-3 数据排序6-4 多项式求值 6-1 输出星期名 请编写函数&#xff0c;根据星期数输出对应的星期名。 函数原…

【LeetCode刷题】--12.整数转罗马数字

12.整数转罗马数字 方法&#xff1a;模拟 分析罗马数字的规则是&#xff1a;对于罗马数字从左到右的每一位&#xff0c;选择尽可能大的符号值 根据罗马数字的唯一表示法&#xff0c;为了表示一个给定的整数num&#xff0c;寻找不超过num的最大符号值&#xff0c;将num减去该符…

CyNix

CyNix 一、主机发现和端口扫描 主机发现&#xff0c;靶机地址192.168.80.146 arp-scan -l端口扫描&#xff0c;只开放了80和6688端口 nmap -A -p- -sV 192.168.80.146二、信息收集 访问80端口 路径扫描 gobuster dir -u http://192.168.80.146/ -w /usr/share/wordlists/dir…