【性能测试】资深老鸟,压力测试-大促活动总结,一文打通...

2024-03-19 22:04

本文主要是介绍【性能测试】资深老鸟,压力测试-大促活动总结,一文打通...,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录:导读

    • 前言
    • 一、Python编程入门到精通
    • 二、接口自动化项目实战
    • 三、Web自动化项目实战
    • 四、App自动化项目实战
    • 五、一线大厂简历
    • 六、测试开发DevOps体系
    • 七、常用自动化测试工具
    • 八、JMeter性能测试
    • 九、总结(尾部小惊喜)


前言

1、了解业务活动的必要性

一般情况下压测人员不会与业务人员打交道,对业务也不会有太强的敏感性,所以通常拿到的测试指标都是开发人员提供的。

这很容易会陷入一个误区,如果开发人员对整体业务活动和压测不熟悉,提供的指标可能会与业务活动的压力有较大的差异甚至无法提供。这时就需要专业的性能测试工程师介入熟悉业务活动,评估压力指标。

当然,性能测试工程师并不仅仅只是完成压测,到达既定的压力指标就可以了,还要针对一些特殊的活动制定特殊的压测场景来检验系统是否满足业务需求,举两个栗子:

场景一:抢单模式

A保险产品计划在X月X日的早8点开启销售,全国范围前1W单有优惠,返利30%

那这种场景会有至少3个压力点:

第一个就是大家通常会考虑到的,业务系统每秒或者每分最多可以出多少单。

第二个就比较容易忽略了,那就是销售员会在7点50分~55分之间大量涌入,这对账号管理登录系统及业务系统首页加载有一定的考验。

另一个是最容易忽略也是非常关键的一点:A产品在8点开始销售,那在7点59分之后到8点零几秒的时间内,已经登录进来的销售员会一直不停地刷新产品列表直到A产品开售为止。

假定全国有80W销售员,那这80W人一齐连续刷新产品列表,如果这部分测试场景缺失,性能隐患未发现,导致生产服务器宕机,系统挂掉,那后果就不多说了。

场景二:预付模式

B产品就像某宝一样可以预售,出单流程基本走完,单子暂存至待付款保单模块,到某天的早8点开始付款生效,限售100W单

那这种场景也至少有3个压力点:
前两个压力机基本与场景一一样,区别就是关注最后一两个步骤的性能极限而不是整个出单流程的出单能力里。

第三个点就是当成功缴费之后,保单会存至已售保单。按照正常的思维逻辑与一般行为性,销售员会在保单缴费成功之后去已售保单里面查看。所以这时,对查看已售保单业务的压力会比以往大个好几倍甚至几十倍,这对Redis或者数据库都是非常大的一个考验(面对C端的APP同理)。

所以说只有在充分了解业务活动的情况下,性能测试工程师才能制定完整的压测场景来保障业务,这也是一个优秀的性能质量管理工程师所必备的素质之一。

全链路压测的必要性
现在压测场景已经根据业务活动设计好了,那我们现在继续往下走,聊一聊全链路压测这个话题。

2、性能测试成长阶段简述

阶段一:互联网发展初期,各系统规模较小,业务量也不大,一般情况下都是开发自行测试,没有专业的测试团队。

阶段二:后来衍生出了性能测试团队,由项目/需求来驱动测试。

阶段三:在成长到一定阶段之后就形成了性能测试统一的规范及标准,由被动测试变为主动测试。

阶段四:再往后就是性能评测能力的体系化、平台化,与研发、运维高效合作及赋能。
阶段五:devops开发测试运维一体化。

做不了线上压测,也一定要做到线下的全链路!!!

如果说公司还没有达到线上压测的能力,无法开展,但是线下全链路一定要做!虽然说从硬件资源到压测数据与线上差别较大,但也应该想尽办法去贴近生产环境。

硬件资源:虽然说测试环境的硬件和生产应用无法比拟,但是一定要保证压测环境有一部分性能较优的机器及存储资源供参与活动的系统使用,实在没有也要找领导协调其他环境资源临时使用,否则压测结果毫无参考意义。

系统资源配比:活动条线各系统的资源配置一定要统一,与生产等配或者半配。尤其忌讳A系统等配,B系统四分之一配,C系统半配,这种情况下压测过程中会因为资源问题相互推诿导致压测进度缓慢。

存量数据:通常存量数据也是线下压测的硬伤之一,压测前也是需要通过生产数据脱敏或者造数使得各系统压测数据库存量数据与生产存量数据保持一致或达到同一数量级。

正式压测前的准备工作
目前为止,压测场景和压测基础资源已到位,是否可以开始正式压测?是不是感觉还缺少一些东西?

参数配置检查
执行压测前要对所有系统的中间件、数据库等的参数配置检查。因为有很多开发老师只做研发工作,对JVM,nginx,redis,mysql等相关配置并不熟悉。

在环境搭建阶段使用的是各工具的默认值或者公司统一配置的默认值,因为参数配置和业务压力与机器配置息息相关,某些配置又非常影响性能,所以压测前一定要地毯式地排查一遍。避免因为一些基本参数设置不合理导致压测成本上升与人力物力资源浪费。

服务器资源监控
压测前也要做好对每一台服务器的资源监控及告警设置,这样在压测过程中,如果某个系统或者某个集群因负载较高导致性能下降可以快速定位并且及时解决,提高压测效率。

日志管理
因为压测数据量较大,各系统业务日志输出较多,对于每个系统的日志一定要做好准备工作。例如制作定时清理日志脚本或者在压测场景执行之前执行日志清理脚本等,避免因日志占满磁盘导致服务异常造成压测无效性。

预留资源
现在一般系统都已经是docker容器化部署,准备一些预备资源可以在集群扩容,或者有新业务模块需要临时压测等情况下有效减少服务器准备时间以提高压测效率。

各项目组压测接口人
指定的各系统接口人可以协助测试人员在压测中及时响应,快速解决问题,如果有条件最好能集中到一起进行办公,这样的压测效率提升是非常明显的。

达到压测指标是否可以结束测试
当测试结果可以达到目标时,恭喜你,已经完成了整个测试的三分之一。也许你现在会有疑问,为啥才三分之一?

那我现在问:
每个系统的每个服务,单节点可以支撑多少业务量?
如果活动期间突然有超预期的流量访问时,系统能够承受住多少并发,进不来的流量怎么办,会不会对正在销售的产品有影响?
如果要扩容,要扩多少,需要多久?
如果业务流程中,XX关键业务服务突然异常,重启服务需要多久才能恢复正常?
调用第三方接口时,如果响应较慢或者无响应,是否有应急机制?

这一系列的问题牵涉到了服务限流设计,服务熔断设计,服务降级设计,应急预案设计及演练等问题,都需要压力测试来做验证及演练。所以说测试结果可以达到目标也许只是走完了一小步,后面线性测试,极限测试,破坏性测试,稳定性测试,应急预案演练等场景都在等着你。

参与活动保障
压力结束,终于等到了活动这一天,要开始休息了吗?不!
如果有机会,一定要到活动保障现场,不仅仅是在人群中露个脸,你要关注活动压力有没有按照预期到来,压力有多大。各系统性能表现以及业务量。

通过观察记录活动数据来确认压测场景有否符合预期,有没有遗漏的压测点。这样后面再制定测试方案时就会更加全面与完整。

复盘的重要性
不要质疑复盘的重要性,团队与个人的成长可以在复盘的过程中极速提升。

下面是我整理的2024年最全的软件测试工程师学习知识架构体系图

一、Python编程入门到精通

请添加图片描述

二、接口自动化项目实战

请添加图片描述

三、Web自动化项目实战

请添加图片描述

四、App自动化项目实战

请添加图片描述

五、一线大厂简历

请添加图片描述

六、测试开发DevOps体系

请添加图片描述

七、常用自动化测试工具

请添加图片描述

八、JMeter性能测试

请添加图片描述

九、总结(尾部小惊喜)

不论此刻身处何地,只要心中燃起奋斗的火焰,勇往直前,必将书写出属于自己的辉煌篇章;坚持不懈,终将收获耀眼成就。

在逆境中磨练意志,在挑战中突破自我,只有坚持奋斗,才能看见成功的曙光;勇敢面对困难,坚定前行,未来的辉煌将属于你!

奋斗是通往梦想的道路,坚持是抵达成功的船票;每一份努力都在积累成就,每一步坚定都在铺就辉煌。相信自己,你定能创造无限可能!

这篇关于【性能测试】资深老鸟,压力测试-大促活动总结,一文打通...的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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

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

一文带你理解Python中import机制与importlib的妙用

《一文带你理解Python中import机制与importlib的妙用》在Python编程的世界里,import语句是开发者最常用的工具之一,它就像一把钥匙,打开了通往各种功能和库的大门,下面就跟随小... 目录一、python import机制概述1.1 import语句的基本用法1.2 模块缓存机制1.

Python中实现进度条的多种方法总结

《Python中实现进度条的多种方法总结》在Python编程中,进度条是一个非常有用的功能,它能让用户直观地了解任务的进度,提升用户体验,本文将介绍几种在Python中实现进度条的常用方法,并通过代码... 目录一、简单的打印方式二、使用tqdm库三、使用alive-progress库四、使用progres

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

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

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

如何测试计算机的内存是否存在问题? 判断电脑内存故障的多种方法

《如何测试计算机的内存是否存在问题?判断电脑内存故障的多种方法》内存是电脑中非常重要的组件之一,如果内存出现故障,可能会导致电脑出现各种问题,如蓝屏、死机、程序崩溃等,如何判断内存是否出现故障呢?下... 如果你的电脑是崩溃、冻结还是不稳定,那么它的内存可能有问题。要进行检查,你可以使用Windows 11

Java向kettle8.0传递参数的方式总结

《Java向kettle8.0传递参数的方式总结》介绍了如何在Kettle中传递参数到转换和作业中,包括设置全局properties、使用TransMeta和JobMeta的parameterValu... 目录1.传递参数到转换中2.传递参数到作业中总结1.传递参数到转换中1.1. 通过设置Trans的

一文带你搞懂Nginx中的配置文件

《一文带你搞懂Nginx中的配置文件》Nginx(发音为“engine-x”)是一款高性能的Web服务器、反向代理服务器和负载均衡器,广泛应用于全球各类网站和应用中,下面就跟随小编一起来了解下如何... 目录摘要一、Nginx 配置文件结构概述二、全局配置(Global Configuration)1. w

正则表达式高级应用与性能优化记录

《正则表达式高级应用与性能优化记录》本文介绍了正则表达式的高级应用和性能优化技巧,包括文本拆分、合并、XML/HTML解析、数据分析、以及性能优化方法,通过这些技巧,可以更高效地利用正则表达式进行复杂... 目录第6章:正则表达式的高级应用6.1 模式匹配与文本处理6.1.1 文本拆分6.1.2 文本合并6

C# Task Cancellation使用总结

《C#TaskCancellation使用总结》本文主要介绍了在使用CancellationTokenSource取消任务时的行为,以及如何使用Task的ContinueWith方法来处理任务的延... 目录C# Task Cancellation总结1、调用cancellationTokenSource.