性能测试的基本概念

news2024/9/28 9:24:38

学习前的认知

我们在学习性能测试之前,需要有个新的认识:性能测试,不再是像功能测试一样单纯的找 Bug,而是去找性能指标

转变思维
  • 在做功能测试、自动化测试的时候,我们基本都是依托界面进行测试,也称 GUI 测试,我们的目的就是为了跑通功能、程序,并成功找到 Bug
  • 但在做性能测试的时候,我们大部分是 headless 模式(所谓的:无头,无界面模式),目的不再是单纯的为了找到 Bug,而是要分析性能指标等等(后续讲到)

性能测试的时间一般会比自动化、功能测试长,为啥?
  • 因为性能测试的步骤跟自动化、功能测试的步骤不一样,比如说前期的准备(了解系统,环境搭建),后期的压力测试(7*24h)等等
  • 在后面,我们通过讲述性能测试步骤来仔细了解

性能测试一定要工具,手工不行吗?
  • 性能测试是模拟系统在被很多很多用户同时使用时,系统能不能正常使用和提供服务
  • 重点: 很多很多用户
  • 功能测试: 一个人点点点就知道功能通不通,有没有 Bug 了
  • 性能测试: 用手工的话,可以模拟几个、十几个用户,但是当需要模拟上千万个用户时,手工又怎么模拟数据量多的场景呢?
  • 类比,吃饭场景: 一个人可以吃好几碗,但是叫你吃几百碗是不可能的
  • 结论: 工具就可以模拟大数据量的场景,可以做到人做不到的事情

大数据量测试是性能测试吗?
大数据量测试

简单理解:一个接口返回的数据比较多(假设:不使用分页,把所有数据同时返回)

结论
  • 返回大数据量的接口的响应时间会变长
  • 这么大的数据量,我们需要考虑:网络传输数据、服务器查询这些数据、服务器处理这些数据等等分别需要多少时间
  • 这已经跟响应时间挂钩,所以已经属于性能测试的范围,但不归纳于性能分析范围

大数据测试是性能测试吗?

大数据测试的功能属于功能测试哦

性能测试过程发现问题需要立即提交吗?

在性能测试过程中发现一些问题,假设定位到某一段代码有问题,可以截图提交 Bug 给开发,但这并不是我们性能测试的最终目的,最终目的是找出性能指标

有哪些性能指标?
  • 比如说响应时间:10个人、100个人 、1000个人 、10000个人向服务器发起请求,服务器响应请求的平均响应时间是多少,这就是一个指标
  • 又好比TPS:服务器在当前的配置下,不同用户数发起请求,服务器的 TPS 处理能力是多少,这也是一个指标
  • 后续详细介绍

性能测试中发现的 Bug 
  • 性能测试过程中发现的 Bug 属于一个衍生品,并不是最终得到的结果
  • 但像功能测试,最终目的就是为了找出 Bug

关于这个问题的总结
  • 做性能测试,当数据量变大后,会出现连接超时、连接拒绝、500、502 异常问题;在性能测试中,这些异常问题基本都会出现的,但不会去立即提 Bug
  • 对于性能测试工程师,我们要做的是分析为什么在当前数据量下会出现连接超时、连接拒绝,响应时间超时、服务器异常等异常问题
  • 这就需要我们去分析性能瓶颈,并不会单独去某个异常问题出现在哪里,而是分析为什么会出现这个异常问题,分析的是服务器或者是代码,而不是让开发人员马上来修复这些异常问题

我们常说的压测是指压力测试吗?
  • 并不是,而是指负载测试,一般都是为了找出系统的最大负载量
  • 就好像你老板说:你去压测下,看看系统能支撑多少用户同时访问我们的系统

什么是性能测试?

狭义理解
  • 通过工具,找出或获得系统在不同工况下的性能指标值
  • 性能测试过程中,重点是找出****性能指标,而不再是找出 Bug,
  • 性能测试的产出绝对不只是 Bug

场景类比

跑步100米,用时多少?运动员的心跳、步伐频率是多少?

  1. 跑步100米:业务场景
  2. 用时多少:响应时间
  3. 运动员的心跳、步伐:性能指标值

性能指标值和响应时间是否满足当前业务场景的最低要求(合格线)

什么时候能找出性能指标值
假设当前有一个业务

电商系统,下单业务,目前还不知道系统支持多少人同时下单,那么我们需要找到服务器能正常支持多少人同时下单

性能测试初始阶段(第一次做)
  • 先把基础的性能指标值找出来 (第一次性能测试也叫做基准测试)
  • 比如:100个人同时下单系统正常,但120个人同时下单就会出现部分请求的响应时间超长,连接异常
  • 那么100-120范围内的某个值就是当前服务器能达到的性能指标值 (基准值)

版本迭代,进行第二次做性能测试,重新跑一遍之前的性能脚本
  • 又会得到一些性能指标值,对比上个版本的性能指标值,看是否有优化(性能变化)
  • 假设这个时候120个人同时下单是正常的,150个人才有异常,那么接口已经有优化了

假设公司是从0开始做性能测试
  • 第一阶段:做好性能测试,得到性能指标值
  • 第二阶段:假设性能比之前差,哪些性能指标值不满足预期值,就需要分析是哪里有问题

广义理解
  • 只要与服务器性能指标相关的测试都属于性能测试
  • 比如:响应时间、并发用户数、服务器处理能力、吞吐量等性能指标
  • 负载测试、压力测试、容量测试、可靠性测试都属于性能测试
  • 通常嘴巴上说的做性能测试就是广义的性能测试,它包括了很多内容,并不只是针对某一个测试类型

“官方”解释

以下含义来源高老的解释,比较“官方”的术语

  1. 性能测试针对系统的性能指标,建立性能测试模型
  2. 制定性能测试方案
  3. 制定监控策略
  4. 在场景条件下执行性能场景
  5. 分析判断性能瓶颈并调优
  6. 最终得出性能结果来评估系统的性能指标是否满足既定值

其实也算是一个简洁描述的性测试流程了

注意
  • 性能测试不像自动化测试那样很多东西大家都是公认的,性能测试没有一套标准的知识体系,只能说是相似的
  • 基本每个人都有自己的一套知识体系,就好像高老也会说他给性能测试的定义很大可能会被轰炸一样
  • 只要属于自己的知识体系建立起来了,那么就能助力你正确的完成性能测试
  • 不用太过纠结于哪个人对性能测试概念的解释是最准确的

目前博主是正在学习性能测试的小白一枚,希望通过通俗简单的术语来学懂性能测试,打造属于自己的知识体系,欢迎大家进群与我沟通(870155189)

 什么是负载测试?

概念
  • 逐步增加系统负载,测试系统性能变化,并最终确定系统所能承受的最大负载量
  • 通俗理解: 看看你几斤几两

如何增加负载

通过增加“用户数”,就是常说的并发数

场景类比

天平秤,称东西的时候,需要逐步加砝码,最终达到砝码和物品重量的平衡点,因为它不可能一下子就达到平衡点【好比不可能一下子找到系统能承受的最大负载量】

  • 称东西:业务场景
  • 加砝码:逐步加压
  • 达到平衡点:找到最大负载量

实际场景
  • 有一个业务,增加到40个人的时候,服务器还能正常使用,没有异常
  • 当你增加到50个人的时候,服务器已经开始有异常了,那么就能确定40-50之间某个值就是系统所能承受的最大负载量 【出现性能拐点,找到了服务器性能瓶颈的范围值】
  • 最后减小加压梯度(比如:从40个人开始每次增加1个人、2个人),确认最大负载量 【确认性能拐点】

服务器又有哪些可能会出现的异常呢
  • 响应时间超长: 正常服务器处理请求时间是 1s,但现在变成3s - 5s
  • 服务报错: 无法同时正常响应多个请求
  • 服务器宕机: 系统完全用不了

什么是压力测试?

概念
  • 在较大的性能压力下,持续运行一个比较长的时间,看看系统服务是否正常及系统资源的利用率情况
  • 通俗理解: 鸭梨山大!
  • 关键字: 较大压力 + 较长时间
  • 注意: 不是满负荷压力哦

场景类比

问: 大家什么时候会觉得工作压力大?

答: 996、007;因为你不会觉得955压力山大吧

结论: 所以在我们日常工作中,长时间工作强度高,才会觉得压力大;如果你一周就加班一天也说压力大...(那就别干这一行了)

压力测试用来干嘛的

测试系统的稳定性

类比

工作压力大,你还能坚持下去(那稳定性肯定好吧),那如果你很快就离职了(那稳定性肯定差,都宕机罢工了)

什么时候会做压力测试
  • 生产环境下,系统隔三差五的出现不稳定的情况
  • 这个时候,就需要通过压力测试去测试系统的稳定性情况

啥情况算不稳定?稳定性差?

隔三差五的出现下面的情况

  • 服务异常:响应错误、响应时间超时等
  • 服务器出现异常:宕机

怎么分析是服务异常还是服务器异常 
  • 如果所有请求都是一片红,应用程序发送的所有请求都报红,就是服务器出现了异常
  • 如果有些请求偶尔成功响应,偶尔又失败,则是服务异常,出现不稳定的情况

如何取压力值
  • 在负载测试中,我们确认了系统所能承受的最大负载量
  • 压力值  <  最大负载量,一般取80%左右

灵魂拷问

负载测试一般时间比较短,压力测试时间比较长,持续运行时间短就能正常使用,但持续运行时间长就可能崩掉了,这是什么原因呢?

场景类比
  • 栗子一: 电脑保持开机状态很长时间,会逐渐变卡,因为内存的东西会越来越多,得不到有效的回收, 就会越来越卡
  • 栗子二: 当你经常工作压力很大,且你的心理所能承受的压力逐渐达到最大值时,你就可能会选择离职

总结

压力测试长时间运行,可能会逐渐增加系统的内存占用空间,若得不到有效的内存回收,当达到内存最大值时,系统就会崩掉

压力测试持续运行时间要多久?
  • 标准性能测试里面,一般是7*24小时,或者是它的倍数
  • 但是实际工作中,并不会这么久,否则成本太高
  • 所以会以小时为单位,比如:4个小时、8个小时...晚上下班之后做,第二天早上上班看结果

先负载测试还是压力测试?
  • 先负载测试
  • 负载测试可以找到服务器性能瓶颈的范围值,若生产环境中系统稳定性较差,再做压力测试
  • 所以压力测试是可做可不做的

什么是可靠性测试?

概念
  • 在给定的一定的业务压力下,持续运行一段时间,查看系统是否稳定
  • 关键字: 是否稳定,一定业务压力
  • 注意: 不是较大压力哦

业务场景栗子

电商秒杀场景,几十个商品几十万个人同时秒杀抢购

如何理解可靠性测试
  1. 编写性能脚本:假设一秒内有一万个人同时发起请求
  2. 有压力吗?,一万个人同时发起请求
  3. 但是持续时间,不像压力测试一样需要持续一段时间
  4. 目的是为了验证当这么多人同时发起请求时,成功秒杀的用户能否继续完成后续下单付款等操作 【一定业务压力下,系统是否稳定运行】

什么是容量测试?

概念
  • 在一定的软、硬件条件下,在数据库不同数据量级数据量的情况下,对系统中读/写比较多的业务进行测试,从而获得不同数据量级下的性能指标值
  • 关键字: 不同数据量级

数据库数据量对性能测试结果有没有影响?
肯定有
  • 比如数据库已经有几百条数据和几百万条数据,查询的速度肯定不一样,所以肯定会影响性能测试结果
  • 数据量级的差异,会影响TPS、响应时间、网络等

场景类比

从一袋米中找一个绿豆,和一碗米中找一个绿豆,找的时间肯定是千差万别的

 

总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

 

          视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

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

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

相关文章

人工智能训练师工作内容及职业发展路径

人工智能训练师&#xff08;AI Trainer&#xff09;是一种专业职位&#xff0c;主要负责训练和优化人工智能系统&#xff0c;尤其是机器学习模型。他们的工作涉及到以下几个方面&#xff1a; 1、数据准备&#xff1a;训练师需要收集、清洗和预处理数据&#xff0c;以确保数据的…

大语言模型训练数据常见的4种处理方法

大语言模型训练需要数万亿的各类型数据。如何构造海量“高质量”数据对于大语言模型的训练具有至关重要的作用。虽然&#xff0c;截止到2023 年9 月为止&#xff0c;还没有非常好的大模型的理论分析和解释&#xff0c;也缺乏对语言模型训练数据的严格说明和定义。但是&#xff…

rabbitmq发送的消息接收不到

1.消息被其他消费者消费 2.主要说的2这种情况&#xff0c;就是在延迟队列中&#xff0c;忘记给一个bean加注解导致日志报exchange not found. 这个报错&#xff0c;进而引发了bindings没有绑定。没有绑定的话&#xff0c;发送消息就会接收不到。

python-带空格的数字层三角形

[题目描述] 输入一个整数n&#xff0c;输出一个带空格的数字层状三角形。输入&#xff1a; 输入共一行&#xff0c;为一个整数n。输出&#xff1a; 输出一个带空格的数字层状三角形。样例输入1 8 样例输出1 11111111 2222222 333333 44444 5555 …

亦菲喊你来学机器学习(16) --K-means聚类算法

文章目录 K-means基本步骤优缺点构建模型 总结 K-means K-means 算法是一种广泛使用的聚类算法&#xff0c;旨在将数据集划分为 K 个簇&#xff0c;使得每个簇内的数据点尽可能相似&#xff0c;而不同簇之间的数据点尽可能不同。这个算法通过迭代的方式实现&#xff0c;每次迭…

三耐环保家族控股99.17%:分红6000多万再补流,董事长董秘一年3次被警示

《港湾商业观察》施子夫 王璐 持续冲刺北交所的杭州三耐环保科技股份有限公司&#xff08;以下简称&#xff0c;三耐环保&#xff09;日前收到第三轮审核问询函&#xff0c;其保荐机构为民生证券。 值得关注的是&#xff0c;第三轮审核问询函依旧围绕的问题是&#xff0c;进…

linux系统修改/etc/profile,修改错了,再打开乱码

执行vim /etc/profile&#xff0c; 在文件末尾增加两行配置&#xff0c;可能是$符号写错了&#xff0c;输入:x保存&#xff0c;提示输入密码(help cm),然后输入两次cm 执行source /etc/profile 提 示文件错误字段 执行cat profile结果如下&#xff1a; 这有没有办法还原啊…

省略号(一行多行)vue3

组件 <template><div ref"tooltipParentRef" class"moreTipText"><el-tooltip:placement"props.placement"effect"dark":enterable"true":show-after"200":offset"10":popper-class&qu…

声纹API验证快速检索技术实现

一、实现思路&#xff0c;假如我们有4个人员&#xff0c;要从中快速找到4号的发音&#xff0c;那么我们就可以使用声纹API验证技术。 二、首先我们要创建特征库&#xff0c;然后分别添加到特征库里&#xff0c;随后找另一个人发音不同的音频去快速定位寻找。 三、比如我们要找到…

什么是集成测试?它和系统测试的区别是什么?

01 什么是集成测试&#xff1f; 集成测试是软件测试的一种方法&#xff0c;用于测试不同的软件模块之间的交互和协作是否正常。集成测试的主要目的是确保不同的软件模块能够无缝协作&#xff0c;形成一个完整的软件系统&#xff0c;并且能够满足系统的需求和规格。 在集成测试…

yml Unused property

问题描述 以前用的好好的项目,今天突然打开就发现idea不识别spring配置信息显示未引用,如果config代码中引入的配置却可以高亮显示,然后输入spring相关的配置,文件是没有提示的。经过研究发现是spring相关的插件被关闭了。效果如下 解决方法 启用三个插件spring Boot,Sp…

openEuler:ssh 管理和安全

ssh 简介 ssh 为 secure shell&#xff0c;是一种网络安全协议&#xff0c;通过加密和认证的方式实现远程安全登录&#xff0c;文件传输等服务。利用 SSH 协议可以有效防止远程管理过程中的信息泄露问题。 但是在近期&#xff0c;OpenSSH 爆出首个远程执行漏洞 CVE-2024-6387 …

R18 XR :NR L2 enhancement

这篇主要看下为支持XR,L2都有哪些增强。主要分3个部分:(1)additionalBS-TableAllowed和Delay Status Report(DSR) (2)UE assistance info for UL traffic information (3) PDU set discard。正文开始: 为了增强 XR 上行资源的调度,引入了以下改进: (1)一个额外的buffer s…

c++类(中)续

c类&#xff08;中&#xff09;续 一、日期类&#xff08;1&#xff09;什么是日期类&#xff1f;&#xff08;2&#xff09;日期类的初始化与销毁&#xff08;3&#xff09;我们需要完成的操作(1)初始化与输出日期&#xff08;2&#xff09;日期加等于天数&#xff08;3&#…

Linux实现进度条小程序——缓冲区

&#x1f4dd;Linux实现进度条小程序 &#x1f4dd; 行缓冲区&#x1f4dd; fflush函数&#x1f4dd; 示例&#x1f4dd; 进度条如何编译运行proc.hproc.cmain.c 好雨知时节 当春乃发生 随风潜入夜 润物细无声 回车换行其实是两个概念&#xff0c;一是回车&#xff0c;一是换行…

JAVA毕业设计167—基于Java+Springboot+vue3+小程序的物业管理系统小程序(源代码+数据库+万字论文+文献综述)

毕设所有选题&#xff1a; https://blog.csdn.net/2303_76227485/article/details/131104075 基于JavaSpringbootvue3小程序的物业管理系统小程序(源代码数据库万字论文文献综述)167 一、系统介绍 本项目前后端分离带小程序(可以改为ssm版本)&#xff0c;分为用户、管理员两…

微服务--认识微服务

微服务架构的演变 1. 单体架构&#xff08;Monolithic&#xff09; 阶段描述&#xff1a;在单体应用时代&#xff0c;整个应用程序被设计为一个项目&#xff0c;并在一个进程内运行。这种架构方式开发简单&#xff0c;便于集中管理&#xff0c;但随着应用的复杂化&#xff0c…

[000-01-008].第01节:Nacos开发应用

我的后端学习大纲 SpringCloud学习大纲 2.Nacos功能&#xff1a; Nacos可以作为服务的注册中心&#xff0c;也可以作为服务配置中心&#xff1a; 服务发现与服务健康检查:Nacos使服务更容易注册,并通过DNS或HTTP接口发现其他服务&#xff0c;Nacos还提供服务的实时健康检查&…

无人机遥控器工作原理!!!

一、基本组成 无人机遥控器通常由发射端&#xff08;遥控器本体&#xff09;和接收端&#xff08;安装在无人机上的接收模块&#xff09;两部分组成。发射端包含控制杆、按钮、显示屏等物理控件&#xff0c;用于输入控制指令&#xff1b;接收端则负责接收来自发射端的无线电信…

机器人外呼的具体操作步骤是怎样的?

今天小编给大家整理一下几点关于使用AI机器人拨打电销电话的具体步骤可以归纳为以下几个关键环节&#xff1a; ​ ### 一、选择合适的AI机器人服务 1. **平台选择**&#xff1a; - 选择一个提供AI机器人拨打电话服务的平台&#xff0c;这可以是云端的AI电话机器人服务&#…