51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

查看: 764|回复: 3
打印 上一主题 下一主题

一篇文章教你学会性能测试计划编写

[复制链接]
  • TA的每日心情
    擦汗
    前天 09:08
  • 签到天数: 947 天

    连续签到: 6 天

    [LV.10]测试总司令

    跳转到指定楼层
    1#
    发表于 2023-2-10 10:55:31 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    上篇文章,我们讲过性能测试计划,接下来我们就来讲讲如何设计符合项目的性能测试计划。
      到上篇为止,我们了解了性能测试计划中包含的内容,但是,这个颗粒度,我觉得作为一名测试经验不够丰富的性能工程师来说,还是有些迷茫,只知道理论还不够,如何把性能测试计划落地,才是我们这次的目标。
      所以,接下来,我会结合实际的项目案例,来落地性能测试计划。当然,针对一看就懂的内容,我就不过多唠叨,毕竟,大部分人的想法都是:时间很珍贵,干货要满满。
      设计符合项目的性能测试计划
      背景
      根据你的实际项目来描述即可, 此处省略……
      性能目标
      根据商品在系统中的下发主流程,来测试系统的单接口最大容量;
      根据业务比例设计容量场景,充分利用当前资源,找到当前系统的性能瓶颈,并优化,以达到系统的最佳运行状态;
      根据稳定性场景,判断当前系统可支持的系统最大累加容量;
      根据异常场景,判断当前系统中的异常对性能产生的影响。
      压测范围
      计算接口;
      同步接口;

      在这里,强调一下:需要测试的接口,是业务主流程的主要接口,并不是所有的接口都需要测试。
      我在面试过程中,问求职者这个问题, 大部分都会说所有的接口都会测试一遍,这没必要。
      启停准则
      启动准则:环境准备完毕,架构服务部署完毕,测试计划、测试方案评审完毕、所有功能测试完毕、所有相关人员(PM、架构师、开发工程师、性能测试工程师、运维)已到位;
      结束准则:达到项目需求的性能指标,性能瓶颈已解决,测试报告和调优报告都已完成;
      暂停准则:系统环境出现问题导致无法继续测试,比如网络不同、压力机损坏、服务宕机等;
      在启动准则:上述问题都已解决,可以继续进行测试。
      性能指标
      这里的TPS,可以通过运维提供的数据,进行预估。
      根据多年的测试经验,这里的TPS标准方差不会超过5%,如果超过,那……能为你"点赞"。

      系统架构图
      系统逻辑架构图 和系统部署架构图,你可以与设计沟通或者运维沟通,都可以得到。得到这两个图,需要你去梳理架构逻辑,为你进行性能瓶颈分析做准备。
      压测前准备
      主要是硬件服务的配置信息,这里的资源配置,在评审阶段就可以得到。

      工具准备
      压测工具:Jmeter+InfluxDB。

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

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

      性能设计
      ①性能测试策略,一定是要满足:连续、递增的策略。
      如果你的性能测试策略不满足这两点,那我可以断定,你的性能测试最后的结果,一定不是准确地,或者说一定不会符合实际的生产环境的业务场景。
      ②业务场景,一定要满足 基准场景、容量场景、稳定性场景 和异常场景,否则,最后的结果,一定是跟上面说的一样。
      监控设计
      ①全局监控设计:一定是从整体出发,监控全局系统;如何快速定位问题, 取决于你的全局监控部署的是否完整。
      ②定向监控设计:对具体的应用、数据库等进行监控分析,如 jstack、mysqlreport等。
      全局监控发现问题, 定向监控分析问题,这就是监控布局的整体意义所在,定向监控是分析问题最快最直接最便捷的。
      如果你没有定向监控,即使你的经验在丰富, 分析性能瓶颈也不是最快最准确的。
      项目组织架构
      把你的项目组织架构图画出来, 这样便于发现问题后知道第一时间找谁去处理。
      例如:
      PM:项目负责人;
      架构师:项目架构负责人;
      开发工程师:参与项目编发人员,解决性能问题;
      性能工程师:负责编写性能测试脚本 和负责分析性能瓶颈 , 这两个职位可以是同一个人;
      运维:部署服务,环境构建。

      成果输出
      性能测试报告、性能调优报告、性能测试脚本、性能缺陷列表,在大部分性能测试工程师认为,成果输出中,并不包含性能调优报告,我也调查过很多人,最后我得到的结果,让我很吃惊:
      不知道性能成果还 性能调优报告;
      性能调优报告是什么;
      过程性内容,没必要提供;
      性能调优是开发参与,我一个性能测试工程师,何必管那么多。
      看到这里, 你是不是也很吃惊, 或者刷新了"三观认知"。所以,避免你说出同样的话,建议你在成果输出中包含 性能调优报告。
      项目风险分析
      关于项目分析分析, 你可能会说,项目风险是测试报告中体现的, 为何要在 性能测试计划中体现?
      其实不然, 项目风险分析,是你性能测试开始前期进行分析和评估的。
      例如:
      你的测试环境无法满足与生产环境一样的配置;
      你的业务模型可能因为某些原因,导致与生产环境某一节点不相符;
      由于涉及多团队协作,可能在性能测试过程中,某些人员无法准确到位……
      总结
      看到这里,你是不是已经对如何编写性能测试计划有了重新的认识?我用了大篇幅的内容,从性能测试计划包含哪些内容,到如何落地性能测试计划,就是为了让你在性能测试更专业。
      一份详细的性能测试计划,是整个性能测试工程的关键所在。而在这份性能测试计划中, 更核心的内容,就是:性能指标,系统架构图、性能场景、监控设计。
      所以, 在整个性能测试计划中,你需要把更多的精力,放在更核心的内容上。只有编写详细的性能测试计划, 设定明确的性能指标, 理解系统架构图,设计完整的性能测试场景,部署完整的监控,你的性能测试才算完整。

    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

  • TA的每日心情
    慵懒
    11 分钟前
  • 签到天数: 2670 天

    连续签到: 1 天

    [LV.Master]测试大本营

    4#
    发表于 2023-2-21 14:38:42 | 只看该作者
    其实中间的分析、数据、收集落地过程很重要
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-5-13 08:39 , Processed in 0.068069 second(s), 22 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表