【测试】揭开性能测试的神秘面纱

2024-05-28 13:08

本文主要是介绍【测试】揭开性能测试的神秘面纱,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 前言
    • 常见性能指标
    • 性能测试步骤
      • 准备阶段
      • 执行阶段
      • 分析阶段
      • 调优阶段
      • 验证阶段
    • 结尾


前言

大家好,我是洋子,相信刚学习软件测试的同学都听说过性能测试、压力测试、负载测试、稳定性测试等等,在日常性能测试工作中,我们不用太关心这四者之间有什么区别,因为压力、负载、以及稳定性测试都是属于性能测试的范畴

谈到性能测试,大家可能会想到Jmeter。网上有很多关于Jmeter的学习资料,但是请大家注意,学会Jmeter并不等于掌握了性能测试,Jmeter只是一个测试工具,用来辅助我们执行性能测试,除了Jmeter我们也可以选择其他的工具来执行性能测试。本篇文章不是一篇Jmeter的教程,而是带你了解性能测试完整的工作流程

常见性能指标

在学习性能测试之前,我们需要了解常见的性能相关数据指标。性能测试的对象可以分为服务端客户端

对服务端接口进行性能测试,我们通常会关注如下数据指标

  • 可用性:系统在面对异常时可以提供正常服务的能力
  • QPS(Queries-per-second,每秒查询率):QPS是对一个特定的查询服务器在规定时间内所处理流量多少的衡量标准
  • 平响(平均响应时间):所有请求平均耗费的时间
  • 并发数:并发用户数是指系统可以同时承载的正常使用系统功能的用户的数量。并发数=QPS*平均响应时间
  • PV(Page View):即页面浏览量或点击量,用户每次对网站的访问均被记录,用户对同一页面的多次访问,访问量累计
  • 错误码:接口返回结果的HTTP状态码
  • 吞吐率:单位时间内服务器处理的请求数来描述其并发处理能力
  • 实例存活度:对多个机房实例同时进行性能测试后,实例正常运作的数量
  • 业务关键指标:根据自己业务设定的性能数据指标

而对APP客户端进行性能测试时,关注的指标如下:

  • 内存
  • CPU
  • 网络流量
  • 电量
  • 启动速度
  • 滑动速度、界面切换速度
  • 与服务器交互的网络速度

性能测试步骤

在实际工作当中进行性能测试,一般有如下五个步骤:

  • 准备
  • 执行
  • 分析
  • 调优
  • 验证

下面我以服务端性能测试为例,讲解各阶段该怎么做

准备阶段

需要深入了解性能问题对象并对性能问题进行粗略评估,还需要了解服务的整体架构、对应的服务器信息,对系统应用的熟悉程度,在很大程度上决定了是否能更快的发现问题,比如需要梳理压测接口及接口的依赖下游,准备压测环境,redis缓存的填充,准备接口入参(线上引流或数据构造),监控指标的配置,熔断方案

跟产品经理以及开发沟通本次性能测试的方案,包括确定被测系统、要进行压测的接口,确定本次压测的接口的最高QPS,制定应急预案,确保执行测试出现异常时,有人及时跟进处理

性能测试方案制定完成后,还需要准备监控平台,用于监控当前测试的状态以及各项性能指标

编写压测脚本用于批量发送压测的接口请求,也可以使用Jmeter 这样的测试工具,在成熟的公司里面,一般会有通用的压测平台,配置压测任务即可进行性能测试

执行阶段

在执行性能测试时,若某个接口需要压1000 QPS。我们不会让它立马上涨到 1000,而是设置100 QPS为初始值,增长的步长也为100。因为我们一般是直接对线上环境的接口进行压测,这样做能保证线上服务不受影响,否则一下子提到很高的QPS,服务器可能会压崩溃
在这里插入图片描述

分析阶段

达到预期的QPS以后,我们就可以停止压测,进行数据分析。通过分析准备阶段新增的监控进行收集问题信息,包括系统/业务监控报警,关联系统故障追溯;

此时还可以通过通过性能分析工具对问题进行初步定位

下面几张截图是监控平台上的指标趋势,下图为可用性,可以看到可用性基本是维持在98%-100%
在这里插入图片描述
下图为平均响应时间,基本是在100 ms
在这里插入图片描述

下图为PV,有时候还会采集PV lost数据指标,PV lost是对服务器日志中的status为500状态码的日志做采集
在这里插入图片描述
错误码,正常接口返回错误码是200,下图当中有少量499、404、504的错误码
在这里插入图片描述

调优阶段

当我们在性能测试的指标发现异常后,就需要与开发配合,让开发优化代码修复性能问题

根据定位到的瓶颈点针对性解决,包括应用性能调优,系统部署优化

性能测试发现的常见问题有接口读取数据超时,优化方式一般是优化SQL查询语句、修改索引,或者增加 Redis 缓存直接从缓存读取数据等等

验证阶段

在优化代码完成后,再次进行性能测试,与准备阶段的指标进行对比,观察数据指标是否正常,若已经达到预期效果则可以发送性能测试报告,完成本次压测

结尾

以上就是一个较简单的,完整的性能测试过程,当然其中很有很多值得分析和探讨的内容,大家可以留言一起探讨,看到一张整理得比较好的思维导图送给大家。如果你觉得对你有帮助,麻烦点一个【赞】和【在看】
请添加图片描述
图片来源:https://blog.csdn.net/wangfulong666/article/details/90177729

这篇关于【测试】揭开性能测试的神秘面纱的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1010649

相关文章

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

Redis中高并发读写性能的深度解析与优化

《Redis中高并发读写性能的深度解析与优化》Redis作为一款高性能的内存数据库,广泛应用于缓存、消息队列、实时统计等场景,本文将深入探讨Redis的读写并发能力,感兴趣的小伙伴可以了解下... 目录引言一、Redis 并发能力概述1.1 Redis 的读写性能1.2 影响 Redis 并发能力的因素二、

Golang中拼接字符串的6种方式性能对比

《Golang中拼接字符串的6种方式性能对比》golang的string类型是不可修改的,对于拼接字符串来说,本质上还是创建一个新的对象将数据放进去,主要有6种拼接方式,下面小编就来为大家详细讲讲吧... 目录拼接方式介绍性能对比测试代码测试结果源码分析golang的string类型是不可修改的,对于拼接字

mysql线上查询之前要性能调优的技巧及示例

《mysql线上查询之前要性能调优的技巧及示例》文章介绍了查询优化的几种方法,包括使用索引、避免不必要的列和行、有效的JOIN策略、子查询和派生表的优化、查询提示和优化器提示等,这些方法可以帮助提高数... 目录避免不必要的列和行使用有效的JOIN策略使用子查询和派生表时要小心使用查询提示和优化器提示其他常

SpringBoot中整合RabbitMQ(测试+部署上线最新完整)的过程

《SpringBoot中整合RabbitMQ(测试+部署上线最新完整)的过程》本文详细介绍了如何在虚拟机和宝塔面板中安装RabbitMQ,并使用Java代码实现消息的发送和接收,通过异步通讯,可以优化... 目录一、RabbitMQ安装二、启动RabbitMQ三、javascript编写Java代码1、引入

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

Tomcat高效部署与性能优化方式

《Tomcat高效部署与性能优化方式》本文介绍了如何高效部署Tomcat并进行性能优化,以确保Web应用的稳定运行和高效响应,高效部署包括环境准备、安装Tomcat、配置Tomcat、部署应用和启动T... 目录Tomcat高效部署与性能优化一、引言二、Tomcat高效部署三、Tomcat性能优化总结Tom

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五