关于性能测试平台的一些想法,想跟大家聊一下

news2024/12/26 20:52:29

目录

一、任务管理

二、用例管理

三、环境管理

四、压测机管理

五、数据管理

六、监控管理

七、日志管理

八、报表管理

九、配置管理

十、系统管理


组织架构

这里我按照每个不同系统归属的项目组为横向,性能测试团队作为职能部门为纵向的矩阵式组织架构为例,来介绍性能测试管理平台的构思。

思维导图

性能测试必看视频教程:2023最新的真实企业大厂性能测试全流程的项目实战详解,可以写进简历面试的那种哦_哔哩哔哩_bilibiliicon-default.png?t=N4P3https://www.bilibili.com/video/BV1PW4y1R7ye/?spm_id_from=333.999.0.0

              

一、任务管理

1、任务申请

一般来说,性能测试需求的来源有2个方面:

①、项目组提需求

项目组主动提性能测试需求,需要一个统一的性能测试任务管理的模块,其中包括被测系统归属的项目条线、系统名称、系统架构图、网络拓扑图、相关设计文档及相关环境的配置信息,

以及项目经理、开发、运维、DB等联系方式,还有被测系统交付测试时间,deadline时间等信息。

这种情况又可以分为三种类型:

新系统发布:新的系统发布上线,需要对功能,性能,安全等各方面做一个完整的测试,评估是否达到业务、产品既定的上线要求。

老系统迭代:已有系统进行某些优化,新功能的增加或者新的业务渠道引入,可能带来更高的流量冲击,这时候项目经理或者开发经理会提出相关的性能需求,希望验证已有系统是否满足上线需要。

生产事故修复验证:系统在生产环境遇到性能问题带来了某些损失,经过调优或修复后需要进行一轮全面的性能测试来评估是否满足已有的实际业务需求。

②、性能组提需求

针对项目的迭代、新需求的引入带来的可能存在的性能瓶颈主动提出,然后经过评估,决定是否进行测试,来评估系统的稳定性可用性等。

2、任务审批

性能测试任务申请提交后,就需要项目组、性能组甚至其他相关人员根据现有情况,工作安排,工期等进行综合评估,来决定是否进行性能测试以及何时开始,资源分配的工作。

其中需要涉及到多个团队多个人员的配合和参与,还有不能按期交付带来的风险预估等;关于性能测试需求评审,后续我会专门写篇博客来分析其中的一些细节。

3、任务排期

性能测试任务经过评估后决定进行,接下来就是根据具体的工作安排,资源调配,进行工作排期等进一步的工作。

二、用例管理

这里的用例,我指的是性能测试中包括基于任务类型,资源等各方面情况来建立的业务模型来抽象管理,具体可分为下面三种业务模型:

1、常规任务

常规任务,指的是系统迭代或者新系统发布提出的性能需求,其中包括项目条线、系统名称、架构、拓扑图、相关人员信息、业务模型等具体信息。

根据上述的情况进行具体的被测系统场景建模分析,然后制定具体的测试用例。

2、日常轮询

这一类型可以参考持续集成中的自动执行和条件触发等情况,设立定时任务对范围内的系统进行性能测试,测试类型主要包括并发、多节点等测试类型。

3、全链路压测

全链路压测,主要是生产环境进行的整体业务线的性能测试,

三、环境管理

性能测试开始的前提是有一个稳定可满足性能测试的环境,一般来说都是在下面两种环境进行:

1、UAT

UAT环境即我们俗称的用户验收测试环境,相对来说环境稳定,且配置各方面和生产相同或者可以进行等量代换,能满足常规的性能测试需要。

2、FAT

FAT环境可理解为生产验证测试环境,系统版本,配置、数据量等和生产保持一致,这样从可测试性和真实性上更符合实际的生产情况。

PS:还有全链路压测是在真实的生产环境进行,但是生产环境进行性能测试的风险太大,且对现有系统的改造工作较多,是否进行还需要经过详细的评估才能决定。

全链路压测的挑战在于这几点:

①、业务模型梳理

②、数据问题,包括数据的真实可用性、数据隔离和数据脱敏;

③、环境隔离,不能影响到实际的生产业务;

④、服务集群负载均衡,测试策略和服务间通信的问题;

⑤、容灾问题,包括某些服务宕机或者不可用时,不能对实际生产业务运行造成影响,系统可用性等;

四、压测机管理

1、压测机调度

实际的流量冲击较高时,单个压力机可能无法支持,这时候就需要多个压力执行机来分布式的进行压测。

在实际生产环境,流量的变化很有可能是随机的,如何做好压测执行机的增加和缩小,合理利用资源,是需要考虑和解决的问题。

2、状态管理

这里主要包括压测机的状态变化,包括闲置、使用(甚至预测何时可释放出来供其他压测任务使用等)、不可用(损坏或其他原因)等。

3、异常管理

当性能测试进行过程中,由于某些原因导致服务不可用,就需要及时的停止性能压测,一般来说主要是下面几种手段:

①、手动停止:从管理界面的功能按钮来停止压测执行;

②、熔断措施:即通过监控报警措施,当系统不可用或超过某个阈值时,自动停止压测;

③、兜底手段:当手动停止或者自动熔断措施都不可用时,从外部的某些手段来停止压测执行,这也算一种容灾措施;

性能测试必看视频教程:2023最新的真实企业大厂性能测试全流程的项目实战详解,可以写进简历面试的那种哦_哔哩哔哩_bilibiliicon-default.png?t=N4P3https://www.bilibili.com/video/BV1PW4y1R7ye/?spm_id_from=333.999.0.0

                  

 

五、数据管理

测试是需要数据来驱动的,那么在性能测试中,需要准备哪些数据呢?

1、基础数据

基础数据包括系统业务正常运行所必须的数据,比如:电商平台的SKU信息、库存数据等,还有银行的用户信息、某些业务的相关数据等,可以通过从生产备份等手段来解决。

2、预埋数据

预埋数据主要指的是DB层面,即性能测试需要模拟实际的环境,包括数据量等,从DB层面来说,同一个库表,数据量不同在同样的业务模型下,其性能表现也是不同的。

预埋数据的准备,可以通过从生产备份,或者通过脚本、SQL语句来自定义准备一些可用的数据。

3、测试数据

测试脚本运行所必需的数据,通常可以通过参数化的方式来解决。

当然,从测试平台的角度,解决这个问题的方法可以通过统一的数据池来做管理,界面通过不同的选择项,调用API来生成测试可用的数据。

六、监控管理

性能测试中,监控是必不可少的重要一环,通常来说,需要监控的包括以下几个方面:

1、前端性能

前端展示、资源渲染所花费的时间,哪些资源耗费了最多的时间和资源,都是需要通过监控来得到相关信息。

2、中间件

①、Redis

有些系统架构利用Redis来做持久层或者缓冲区,那么对于缓存的可用性和缓存失效、缓存穿透等信息,也是必须要监控的。

②、MQ

MQ是一个异步的通信框架,类似的还有kafka等框架,对于消息队列的生产和消费速率,资源占用,可能的堵塞等情况进行监控,也是必不可少的。

③、其他

3、容器

现在越来越多的企业开始将服务容器化(特别是在微服务的架构中,容器化是必要的一种手段),包括环境、脚本、服务都放在容器中。

那么对容器资源的监控,也是非常必须的。

4、服务器

服务器的监控,主要是内存、CPU、IO等方面,包括占比、使用率、阈值和提醒等。

5、DB

数据库层面,主要监控的内存、CPU等信息,当然也包括SQL语句执行耗费时间、锁等情况。

6、网络

网络是必不可少的一环,不稳定的网络环境对测试结果的影响很大,可能会带来一些隐藏的问题;网络监控一般关注这几个方面:稳定性、网关、CDN、防火墙等方面。

PS:实际上从上面的几种监控来看,都是从用户层到最终的服务处理层,层层进行监控,做到一切用数据说话。

七、日志管理

在测试过程中,有时候不能从测试数据直观的看到隐藏的问题,就需要查看对应的日志,从详尽的日志中分析爆发问题的节点,然后进行针对性的分析。日志监控,大概分下面几个层级:

1、web

这里可以理解为用户层的日志,包括资源的本地加载、缓存等信息(由于某些情况下详尽的日志包较大,采用了日志写入用户层的操作)。

2、app

这里代指应用层,有时候出现性能问题的原因发生在应用层,那么对应用层的监控,日志分析也是很重要的。

3、service

后台服务层,日志包括处理了哪些操作,哪个请求甚至哪里调用等。

4、DB

数据库日志,同理,哪些操作耗费的时间长、资源多等,都是需要对应的监控和必要的日志分析,才能看出问题。

PS:上述的几种日志管理,从性能测试平台角度来说,都是希望将日志更直观的进行展示、筛选,否则我们需要通过命令或者其他工具的方式,到具体的层级去查找分析日志,这样无疑会浪费一定的时间。

八、报表管理

报表管理主要包括下面几个方面:

1、实时结果

将测试的实时监控结果存入数据库,然后通过grafana等工具展示在界面上,更直观的对测试结果进行管理。

2、测试报告

每轮测试结束,都需要对测试结果进行统计分析,以便于作为一个基点,对下一次测试提供参考和评估依据;测试报告界面可以通过自定义的样式来展现。

3、性能基线

这里的性能基线,指的是:将每次性能测试的最终结果作为一个性能参考基线,后续的每次迭代,以上次性能测试结果为评估点,然后持续更新性能基线,作为下一次的评估依据。

可以通过数据折线、树状图等多种方式来展现,目的是为长期的系统稳定性、可用性做一个监控,为系统调优或重构提供多种维度的参考依据。

九、配置管理

1、挡板

一般来说,性能测试都是通过调用不同的服务接口来进行模拟并发,进行测试,但有时候由于某些原因,导致一部分服务暂时不可用,或者次数限制,这种情况急需要用到mock服务。

①、HttpMock

HTTP是最常见的一种协议,而且随着微服务的流行,restful风格架构设计的运用,HttpMock的挡板服务,就变成一种常规需要。

②、SocketMock

TCP连接也是某些业务系统服务实现通信的方式,为了方便的进行性能测试而降低对其他某些服务的依赖,SocketMock挡板服务,也是必不可少的。

③、其他

包括dubbo接口等其他类型的接口调用,可以针对性的进行设计,将mock变为一种服务。

PS:从测试管理平台的角度来说,将Mock对象编程服务,通过界面进行增删改查的管理,更方便了管理和直观的理解。

2、容器

①、docker

容器化,是这几年越来越流行的一个趋势,对不同的测试环境的docker容器管理,也是必不可少的。

②、虚机

限于不同项目不同技术架构的情况,虚拟机管理这一项,可以根据具体的需要来进行设计,如果全部容器化,那么虚拟机管理,没有也罢。

十、系统管理

1、用户管理

包括使用这个系统的用户注册、新增、删除,状态管理等功能,以及可能需要的任务分配等操作。

2、权限管理

不同的用户角色,分配不同的系统使用权限,可以利用单点登录的原理来设计这一模块。

3、组管理

这里的组管理,我个人理解为基于身份和角色不同所划分的职能组,对其进行新增、权限职能分配、状态变更等功能的管理。

性能测试必看视频教程:2023最新的真实企业大厂性能测试全流程的项目实战详解,可以写进简历面试的那种哦_哔哩哔哩_bilibiliicon-default.png?t=N4P3https://www.bilibili.com/video/BV1PW4y1R7ye/?spm_id_from=333.999.0.0

 

 

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

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

相关文章

JUC学习(二)

目录 Doug Lea — JUC并发包的作者锁框架Lock和Condition接口可重入锁公平锁与非公平锁读写锁锁降级和锁升级队列同步器AQS底层实现公平锁一定公平吗?Condition实现原理 ——————————————————————————————— 在前面,我们了解…

ICV报告:乘光伏新能源汽车之势,功率器件蓄势待发

前言: 电力电子器件(Power Electronic Device),又称为功率半导体器件,用于电能变换和电能控制电路中的大功率(通常指电流为数十至数千安,电压为数百伏以上)电子器件。功率器件能够承受和控制较大电流、电压…

无限阳光、自动收集阳光CALL、阳光产生速度

简单实现无限阳光 本次实验内容:通过逆向分析植物阳光数量的动态地址找到阳光的基址与偏移,从而实现每次启动游戏都能够使用基址加偏移的方式定位阳光数据,最后我们将通过使用C语言编写通用辅助实现简单的无限阳光外挂,在教程开始…

Vue Router路由管理器

目录: 相关理解基本路由几个注意事项嵌套(多级)路由路由的query参数命名路由路由的params参数路由的props配置路由跳转的replace方法编程式路由导航缓存路由组件activated和deactivated路由守卫路由器的两种工作模式 相关理解 vue-route…

博学谷学习记录】超强总结,用心分享 | 架构师 敏捷开发 学习总结

文章目录 敏捷开发1. 概述2. 敏捷开发 敏捷开发 1. 概述 随着软件开发技术的不断发展,现在出现了很多种不同的开发模式,其实敏捷开发已经成为现在很多企业开发应用程序都想要选择的开发方案,那么什么是敏捷开发呢?1.1 四种开发模…

Linux 配置Java环境(一)

Linux 配置Java环境 一、配置Java环境1、查看系统是否有java环境2、卸载系统自带的jdk3、创建一个文件夹用于存放java的压缩包4、包下载好的jdk拖到java文件夹5、安装jdk6、配置环境变量7、让配置生效8、验证是否配置成功 一、配置Java环境 1、查看系统是否有java环境 输入指…

nginx中location和rewrite

常用的Nginx 正则表达式 ^ :匹配输入字符串的起始位置 $ :匹配输入字符串的结束位置 * :匹配前面的字符零次或多次。如“ol*”能匹配“o”及“ol”、“oll” :匹配前面的字符一次或多次。如“ol”能匹配“ol”及“oll”、“olll…

0-1背包问题:动态规划的经典应用

文章目录 引言背包问题简介0-1背包问题定义0-1背包问题的限制条件 动态规划解决思路状态定义状态转移方程 背包问题的Java实现示例与分析 总结 引言 背包问题是在给定一组物品和一个背包容量的情况下,如何选择物品放入背包,以使得放入背包的物品总价值最…

高边功率开关参数Load current(ISO)和Nominal current

1. IL(nom)是没有加散热片的情况下,考虑RON和BTS6133D与环境热阻计算得到的电流值; 2. IL(iso)是有散热片的情况下计算得到的电流值; 3. IL12(SC)是如果负载电流达到75A以上,BTS6143D会通过不断重启来来限制电流在75A以下。

【论文简述】GeoMVSNet: Learning Multi-View Stereo with Geometry Perception(CVPR 2023)

一、论文简述 1. 第一作者:Jie Zhu 2. 发表年份:2023 3. 发表期刊:CVPR 4. 关键词:MVS、级联结构、几何感知、频域增强、高斯混合模型 5. 探索动机:基于级联的结构以从粗到细的方式计算不同分辨率的深度图&#x…

数据结构与算法练习(二)数组模拟队列

文章目录 1、队列2、数组实现队列3、数组实现循环队列 1、队列 队列是一个有序列表,可以用数组或链表来实现 遵循先入先出的原则 在队尾插入元素叫做入队,对头删除元素叫做出队。2、数组实现队列 思路: 用front和rear记录队列前后的下标&a…

【MCS-51单片机汇编语言】期末复习总结⑤——定时器中断方式与查询方式程序设计(题型五)

文章目录 知识准备工作方式寄存器TMODTCON寄存器IE寄存器 定时/计数器的使用初始化 常考题型例题1题目描述题目解析题解 例题2题目描述题目解析题解 知识准备 工作方式寄存器TMOD D7D6D5D4D3D2D1D0TF1TR1TF0TR0IE1IT1IE0IT0 [注]:TMOD高4位与T1相关,低…

iptables和防火墙

文章目录 1.防火墙2.Iptables基本介绍2.1 什么是iptables2.2 什么是包过滤防火墙2.3 包过滤防火墙如何实现 1.防火墙 Linux防火墙主要工作在网络层,针对 TCP/IP 数据包实施过滤和限制,典型的包过滤防火墙,基于内核编码实现,具有非…

Qt(C++)绘制指针仪表盘显示当前温度

一、功能介绍 当前文章要实现的功能: 使用Qt绘制一个仪表盘,用来显示当前的温度,绘制刻度、绘制数字、绘制温度指针。仪表盘全程使用QPainter进行绘制,QPainter是Qt框架中非常重要的一个类,绘制功能的实现离不开它。如果想要使用Qt进行高质量的绘图或UI设计,必须掌握QP…

Groovy 基本语法

一、简介 类型转换:当需要时,类型之间会自动发生类型转换: 字符串(String)、基本类型(如int) 和类型的包装类(如Integer) 类说明:如果在一个groovy 文件中没有任何类定义,它将被当做script 来处理,也就意味着这个文件将…

DragGAN-点对点的手动P图

原文网站link以及论文链接: https://vcai.mpi-inf.mpg.de/projects/DragGAN/ https://arxiv.org/pdf/2305.10973.pdf 简介 深度生成模型近年在合成随机真实感图像方面取得了不错的成绩。在现实世界的应用中,这种基于学习的图像合成方法中一个关键功能是…

文心一言 VS 讯飞星火 VS chatgpt (31)-- 算法导论5.2 3题

三、利用指示器随机变量来计算掷n 个骰子之和的期望值。 文心一言: 为了计算掷n个骰子之和的期望值,我们需要先了解一个重要的概念:指示器随机变量。 指示器随机变量是一种特殊的随机变量,它只有两个取值:0和1。通常…

《计算机网络——自顶向下方法》精炼——3.7(2)

读书有三到:谓心到,眼到,口到。——明朱熹 文章目录 对链接吞吐量的简化描述高带宽路径的TCP公平性 对链接吞吐量的简化描述 为了简化对一条TCP连接吞吐量的描述,我们首先忽略连接过程中处于慢启动状态的时间,因为这一…

AWD练习平台搭建 附虚拟机资源

文章目录 前言基本环境平台搭建系统安装平台部署环境启动实现效果 参考后记 前言 最近需要准备线下AWD了,但是没有那么多金币每天上BugKu的PVP在线AWD对战进行练习,于是想着可以自己搭建一个团队内部使用的AWD攻防平台,浅浅的记录一下 基本…

基于SSM框架的学生信息管理系统

项目介绍 主要功能: 基于Spring、SpringMVC、Mybatis框架LayUI完成了这么一套系统 ①角色登录:管理员登录、教师登录、学生登录 ②基本管理:学生管理、教师管理、班级管理、专业管理、教室管理 ③教务管理:课程管理、开课管理、课…