全链路压测演进之迭代式压测

2023-09-20 15:25:12

文章导读

1.背景原因

2.压测流程改进分析

3.迭代式压测流程

压测服务的稳定性 压测环境的稳定性 压测时效 压测人员 贴合业务

4.全流程压测模式演进

5.压测模式对比

6.迭代式压测反馈效果

7.总结

1.背景原因

!! 做系统服务压测都是比较耗时耗人力的,特别是在生产环境上做压测,压测的时间都是在晚上23点后,甚至在凌晨1-4点,每次投入的人力成本较高(经常是晚上通宵加班压测,疲惫感十足),对于团队来说,每次大家都很辛苦,但是又不得不做,这是非常苦恼的烦心事。

为了缓解团队每次投入做压测的疲惫感,以及降低投入的人力成本,对现有的压测流程做进一步的改善:现有的压测模式:常态化压测(例行压测,摸底压测)、大促全链路压测,这两种压测模式的执行是根据现有业务发展而制定的,但都存在一定时效上的问题,且投入人力成本也不低。

为推进常态化压测更高效,更贴近业务进行压测,且分化所有业务流量的焦点集中在大促压测上,把一些常规压测操作前置到日常业务迭代需求项目上,根据中、大规模的需求项目试行迭代式压测,提供更细致、更小范围的压测方式,尝试解决在压测上的时效和人力问题

2.压测流程改进分析

(1)以往的压测模式,主要是常态化压测为主,全链路压测为辅,压测时间段也只有特定的几个时间段(618大促,双11大促等)才会安排。

(2)每次压测主要针对大促流量的性能指标上考虑,而各服务本身的每个环节存在的问题,等到全链路压测的时候才暴露出来,往往已经滞后了很多(线上压测存在的弊端)。

(3)压测的投入,虽然每次的压测都能拿想要的结果,但是人力的成本和时效,并不是很理想。

(4)服务间相互的调量大小,以及能承载多少请求,只有通过常态化压测/全链路压测才发现存在的问题,日常缺少沉淀,经常压测过程会有超时、限流、熔断等情况出现,导致压测的有效性降低

3.迭代式压测流程

结合分析的方向,制定迭代式压测流程如下:

结合公司现有的压测流程,以及存在的不足问题综合分析考虑,把现有的压测流程做调整优化(降本增效),通过日常迭代项目上线后做压测,即可做到贴合业务,以可满足压测需要,主要有以下5个方向改进:

压测服务的稳定性

通过迭代项目上线后压测,可以提前了解到服务本身的稳定性,是否有存在隐藏的问题。日常迭代需求较多,关联依赖也多,上线后压测可以快速了解影响范围,及隐藏的性能问题,如有问题,可根据项目迭代,灵活安排优化版本上线。

压测环境的稳定性

以往生产环境压测,机器存在问题,经常是通过扩容/或更换机器的方式,临时解决,并不能提前知道原因是什么,处理结果相对是滞后的。通过日常迭代项目的压测,可以提前暴露出在日常条件下生产环境机器是否存在问题,为大促压测提前做规避措施

压测时效

快进快出,项目上线后,最小单位安排压测任务,且主要以定时压测为主,灵活压测时间,第二天上班收集压测报告,快速得出压测结果

 

压测人员

(1)降低产研发团队QA的学习门槛,把压测流程和压测平台做到足够简单

(2)不再局限于特定的几个人才能做压测,让业务团队每个QA都能有参与压测的机会

贴合业务

日常迭代项目,参与项目的成员,根据业务的特性评估是否压测:

(1)如不需要压测,后续则降低/不考虑该业务场景对大促活动的影响面

(2)需要压测,则评估影响面范围:

 

复制代码

后端重构项目,影响主流程业务 业务需求新增/变更,涉及有核心接口场景 核心业务场景调整 依赖服务接口变更 ……

以项目维度评估压测范围比较小,能快速明确压测的指标,以及压测场景

(3)增加业务QA人员对压测的参与度,同时让个人在过程可以学习到相关性能测试的知识技能,可作为常态的测试手段

(4)刚好项目测试完,熟悉度还比较热乎,花费最低成本去创建压测脚本和压测数据,定时压测完成后,得出结果进行分析的成本也比较低

 

(5)项目维度的压测结果沉淀,对后续大促压测场景规划,提供更明确压测范围,以及可以提前规避掉服务存在的瓶颈问题

4.全流程压测模式演进

【压测流程流向】

以小聚多,把迭代式压测作为最小压测单位,最后汇总为例行压测(常态化压测)、全链路压测,保障各种链路维度覆盖业务不同颗粒度。参考:常态化压测 、全链路压测

【服务流量流向】

 5.压测模式对比

6.迭代式压测反馈效果

【业务价值】

2月份开始以来,已完成几个需求的压测,压测过程能明显暴露出6个服务隐藏的性能问题,为业务服务规避掉隐藏的性能风险。

【结果反馈】

 

7.总结

(1)业务团队的QA人员需要具备一定的性能测试技能,学会识别项目需求中是否存在隐藏的性能风险

(2)以项目需求作为压测单位,可能不会覆盖到服务所有功能,但在日常迭代过程,迭代式压测相对会比较频繁,以点到面的切入条件,被压测的功能也会逐步积少成多

(3)稀释大促全链路压测和常态化压测准备及计划的压力,融入需求生命周期管理,轻量分布式的完成压测资产沉淀

最后:下面是配套学习资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!

软件测试面试小程序

被百万人刷爆的软件测试题库!!!谁用谁知道!!!全网最全面试刷题小程序,手机就可以刷题,地铁上公交上,卷起来!

涵盖以下这些面试题板块:

1、软件测试基础理论 ,2、web,app,接口功能测试 ,3、网络 ,4、数据库 ,5、linux

6、web,app,接口自动化 ,7、性能测试 ,8、编程基础,9、hr面试题 ,10、开放性测试题,11、安全测试,12、计算机基础

  全套资料获取方式:点击下方小卡片自行领取即可

更多推荐

Flink——Flink检查点(checkpoint)、保存点(savepoint)的区别与联系

FlinkcheckpointCheckpoint是Flink实现容错机制最核心的功能,能够根据配置周期性地基于Stream中各个Operator的状态来生成Snapshot,从而将这些状态数据定期持久化存储下来,从而将这些状态数据定期持久化存储下来,当Flink程序一旦意外崩溃时,重新运行程序时可以有选择地从这些Sn

【校招VIP】前端专业课之七层模型

考点介绍OSI七层参考模型将通信协议中必要的功能分成了7层。通过这些分层,可以将比较复杂的网络协议更加简单化。将每个分层独立使用,即使系统中某些分层发生变化,也不会波及整个系统。前端专业课之七层模型-相关题目及解析内容可点击文章末尾链接查看!一、考点题目1.以下哪一项与传输层面向连接服务无关A.两端之间传输数据前存在协

【JAVA】String类

作者主页:paperjie_的博客本文作者:大家好,我是paperjie,感谢你阅读本文,欢迎一建三连哦。本文录入于《JAVASE语法系列》专栏,本专栏是针对于大学生,编程小白精心打造的。笔者用重金(时间和精力)打造,将javaSE基础知识一网打尽,希望可以帮到读者们哦。其他专栏:《JAVA》《算法详解》《C语言》等内

Spring 声明式事务机制

😀前言本篇是Spring声明式事务系列的第二篇介绍了Spring声明式事务机制🏠个人主页:尘觉主页🧑个人简介:大家好,我是尘觉,希望我的文章可以帮助到大家,您的满意是我的动力😉😉在csdn获奖荣誉:🏆csdn城市之星2名⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣⁣💓Java全栈群星计划

IP地址处理攻略:数据库中的存储与转换方法

🌷🍁博主猫头虎带您GotoNewWorld.✨🍁🦄博客首页——猫头虎的博客🎐🐳《面试题大全专栏》文章图文并茂🦕生动形象🦖简单易学!欢迎大家来踩踩~🌺🌊《IDEA开发秘籍专栏》学会IDEA常用操作,工作效率翻倍~💐🌊《100天精通Golang(基础入门篇)》学会Golang语言,畅玩云原生,走遍大

GaussDB数据库SQL系列:DROP & TRUNCATE & DELETE

目录一、前言二、GaussDB的DROP&TRUNCATE&DELETE简述1、命令简述2、命令比对三、GaussDB的DROPTABLE命令及示例1、功能描述2、语法3、示例四、GaussDB的TRUNCATE命令及示例1、功能描述2、语法3、示例4、示例五、GaussDB的DELETE命令及示例1、功能描述2、注意

Vue3封装知识点(三)依赖注入:project和inject详细介绍

Vue3封装知识点(三)依赖注入:project和inject详细介绍文章目录Vue3封装知识点(三)依赖注入:project和inject详细介绍一、project和inject是什么二、为了解决什么问题三、project和inject如何使用1.provide()2.inject()3.和响应式数据配合使用4.使用

Android 12 源码分析 —— 应用层 五(SystemUI的StatusBar类的启动过程和三个窗口的创建)

Android12源码分析——应用层五(SystemUI的StatusBar类的启动过程和三个窗口的创建)更新历史日期内容12023-9-18修改关于mLightsOutNotifController的错误注释在前面的文章中,我们介绍了SystemUIApp的基本布局和基本概念。接下来,我们进入SystemUI应用的各

java面试题基础第七天

一、java面试题第七天1.throw和throws的区别?throw:用于抛出一个异常对象throws:写在方法体上面,将方法体里面的异常,抛给上层2.通过故事讲清楚NIO下面通过一个例子来讲解下。假设某银行只有10个职员。该银行的业务流程分为以下4个步骤:1)顾客填申请表(5分钟);2)职员审核(1分钟);3)职员

爬虫 — Bs4 数据解析

目录一、介绍二、使用三、Bs4对象种类1、tag:标签2、NavigableString:可导航的字符串3、BeautifulSoup:bs对象4、Comment:注释四、遍历文档树1、遍历子节点2、获取节点内容3、遍历父节点4、遍历兄弟节点五、常用方法六、CSS选择器七、案例一、介绍Bs4(beautifulsoup

初识自动驾驶技术之旅 第一课 学习笔记

​🎬岸边的风:个人主页🔥个人专栏:《VUE》《javaScript》⛺️生活的理想,就是为了理想的生活!​目录📚前言📘1.自动驾驶人才需求与挑战📘2.Apollo8.0开源平台详解📘3.如何使用Apollo学习自动驾驶[上机学习]📘4.如何使用Apollo学习自动驾驶[上车学习]📚总结📚前言讲师介绍:

热文推荐