如何编写性能测试计划?一篇文章教你设计符合项目的性能测试计划

上一篇 / 下一篇  2023-02-21 16:48:53 / 个人分类:性能测试

上篇文章,我们讲过性能测试计划,接下来我们就来讲讲如何设计符合项目的性能测试计划。

到上篇为止,我们了解了性能测试计划中包含的内容,但是,这个颗粒度,我觉得作为一名测试经验不够丰富的性能工程师来说,还是有些迷茫,只知道理论还不够,如何把性能测试计划落地,才是我们这次的目标。

所以,接下来,我会结合实际的项目案例,来落地性能测试计划。当然,针对一看就懂的内容,我就不过多唠叨,毕竟,大部分人的想法都是:时间很珍贵,干货要满满。

设计符合项目的性能测试计划

背景

根据你的实际项目来描述即可, 此处省略……

性能目标

根据商品在系统中的下发主流程,来测试系统的单接口最大容量;

根据业务比例设计容量场景,充分利用当前资源,找到当前系统的性能瓶颈,并优化,以达到系统的最佳运行状态;

根据稳定性场景,判断当前系统可支持的系统最大累加容量;

根据异常场景,判断当前系统中的异常对性能产生的影响。

压测范围

计算接口;

同步接口;

在这里,强调一下:需要测试的接口,是业务主流程的主要接口,并不是所有的接口都需要测试。

我在面试过程中,问求职者这个问题, 大部分都会说所有的接口都会测试一遍,这没必要。

启停准则

启动准则:环境准备完毕,架构服务部署完毕,测试计划、测试方案评审完毕、所有功能测试完毕、所有相关人员(PM、架构师、开发工程师、性能测试工程师、运维)已到位;

结束准则:达到项目需求的性能指标,性能瓶颈已解决,测试报告和调优报告都已完成;

暂停准则:系统环境出现问题导致无法继续测试,比如网络不同、压力机损坏、服务宕机等;

在启动准则:上述问题都已解决,可以继续进行测试。

性能指标

这里的TPS,可以通过运维提供的数据,进行预估。

根据多年的测试经验,这里的TPS标准方差不会超过5%,如果超过,那……能为你"点赞"。

系统架构图

系统逻辑架构图 和系统部署架构图,你可以与设计沟通或者运维沟通,都可以得到。得到这两个图,需要你去梳理架构逻辑,为你进行性能瓶颈分析做准备。

压测前准备

主要是硬件服务的配置信息,这里的资源配置,在评审阶段就可以得到。

工具准备

压测工具:Jmeter+InfluxDB。

监控工具:Promethues、Grafana、Kafka、Logstash、Spring Boot Admin等。

数据准备

测试脚本数据的准备,由于我的项目需要读取文件的方式往数据库里面写数据,所以,txt文件里面的数据,我也是写脚本自动生成的。

性能设计

①性能测试策略,一定是要满足:连续、递增的策略。

如果你的性能测试策略不满足这两点,那我可以断定,你的性能测试最后的结果,一定不是准确地,或者说一定不会符合实际的生产环境的业务场景。

②业务场景,一定要满足 基准场景、容量场景、稳定性场景 和异常场景,否则,最后的结果,一定是跟上面说的一样。

监控设计

①全局监控设计:一定是从整体出发,监控全局系统;如何快速定位问题, 取决于你的全局监控部署的是否完整。

②定向监控设计:对具体的应用、数据库等进行监控分析,如 jstack、mysqlreport等。

全局监控发现问题, 定向监控分析问题,这就是监控布局的整体意义所在,定向监控是分析问题最快最直接最便捷的。

如果你没有定向监控,即使你的经验在丰富, 分析性能瓶颈也不是最快最准确的。

项目组织架构

把你的项目组织架构图画出来, 这样便于发现问题后知道第一时间找谁去处理。

例如:

PM:项目负责人;

架构师:项目架构负责人;

开发工程师:参与项目编发人员,解决性能问题;

性能工程师:负责编写性能测试脚本 和负责分析性能瓶颈 , 这两个职位可以是同一个人;

运维:部署服务,环境构建。

成果输出

性能测试报告、性能调优报告、性能测试脚本、性能缺陷列表,在大部分性能测试工程师认为,成果输出中,并不包含性能调优报告,我也调查过很多人,最后我得到的结果,让我很吃惊:

不知道性能成果还 性能调优报告;

性能调优报告是什么;

过程性内容,没必要提供;

性能调优是开发参与,我一个性能测试工程师,何必管那么多。

看到这里, 你是不是也很吃惊, 或者刷新了"三观认知"。所以,避免你说出同样的话,建议你在成果输出中包含 性能调优报告。

项目风险分析

关于项目分析分析, 你可能会说,项目风险是测试报告中体现的, 为何要在 性能测试计划中体现?

其实不然, 项目风险分析,是你性能测试开始前期进行分析和评估的。

例如:

你的测试环境无法满足与生产环境一样的配置;

你的业务模型可能因为某些原因,导致与生产环境某一节点不相符;

由于涉及多团队协作,可能在性能测试过程中,某些人员无法准确到位……

总结

看到这里,你是不是已经对如何编写性能测试计划有了重新的认识?我用了大篇幅的内容,从性能测试计划包含哪些内容,到如何落地性能测试计划,就是为了让你在性能测试更专业。

一份详细的性能测试计划,是整个性能测试工程的关键所在。而在这份性能测试计划中, 更核心的内容,就是:性能指标,系统架构图、性能场景、监控设计。

所以, 在整个性能测试计划中,你需要把更多的精力,放在更核心的内容上。只有编写详细的性能测试计划, 设定明确的性能指标, 理解系统架构图,设计完整的性能测试场景,部署完整的监控,你的性能测试才算完整。

添加微信:atstudy-js  或者扫描下方二维码,备注“博客”邀请你进入Python自动化测试学习交流群~


TAG:

 

评分:0

我来说两句

Open Toolbar