news 2026/4/3 1:25:22

从压测到调优:一次完整的性能测试实战复盘

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
从压测到调优:一次完整的性能测试实战复盘

在企业中完成性能测试项目是一个挑战性强、技术含量高的任务。本文将分享一个公司完成高性能游戏系统的性能测试过程,展示如何完成一次成功的性能测试项目

项目背景:这是一家游戏公司,推出了一款新的游戏软件,系统要求高性能、高并发、高可用,为确保用户体验和游戏体验,公司决定在正式上线前对系统进行性能测试。

第一步:

定义测试目标

在项目启动之初,团队首先进入到定义测试目标的阶段,据此来确定测试范围、测试手段和测试工具。此阶段重要性不言而喻,目标不明,则结果无从说起。

通过团队讨论,确立了以下的目标:

  • 针对目标场景下的指标进行基准测试,并得到高可用性的性能数据。

  • 评测流量下的异常场景,确定系统多少负载能力及扩展架构。

  • 通过性能测试结果来查找和定位系统的瓶颈,并通过在代码层面进行优化提升系统吞吐量及性能表现。

  • 揭示用户最有可能使用系统的行径模式及环境和业务决策。

第二步:

测试计划调研

按照测试目标,测试团队进行测试计划调研。我们将基于应用程序不断压测及观察应用程序的运行状况来判定应用程序的瓶颈,并且对观察结果进行分析和总结,为分析改善提供有力数据支撑。

针对要测的业务模式,我们设计出了4个具有典型意义的场景:

  • 500-10000个并发用户请求。

  • 负载测试,根据实际场景数据模拟用户操作习惯,

  • 容量测试,以应用程序在各个方面的性能和资源限制,并确定系统配置的最大极限。

  • 24小时稳定性测试,保证系统在持续24小时真实环境下的高可用性。

第三步:

执行测试计划

通过测试计划调研,我们进行了测试项目将近1个月的时间安排到执行。我们使用了多种工具,应用于不同测试领域,例如LoadRunner、JMeter、Appdynamics、Keynote、Fiddler、Wireshark、Flume等等。在这里不展开程序设计中复杂的使用。

下面是使用JMeter测试的例子,它是一款开源的压力测试工具。它可以对不同种类的服务器、网络协议进行测试。

下面是相关的测试结果:

基准测试:

将系统在低负载环境下按照预定的标准进行性能测试,例如单用户响应时间,服务器负载以及数据库处理能力都是很好的评估指标。测试结果如下所示:

测试指标

结果

每秒事务处理能力

7500

平均响应时间

0.3秒

CPU使用率

70%

内存使用率

60%

负载测试:

使用模拟混合负载的测试,在同一时刻模拟大量高并发用户同时访问系统,测试结果如下所示:

测试指标

结果

每秒事务处理能力

13800

平均响应时间

2秒

最大响应时间

5秒

CPU使用率

85%

内存使用率

80%

容量测试:

容量测试中使用jMeter模拟出可实现的并发用户访问系统,测试结果如下所示:

测试指标

结果

每秒事务处理能力

28000

平均响应时间

7秒

最大响应时间

15秒

CPU使用率

99%

内存使用率

95%

稳定性测试:

保证系统在持续24小时真实环境下的高可用性,测试结果如下所示:

测试指标

结果

24小时无故障时间

CPU使用率

85%

内存使用率

92%

第四步:

测试结果及异常分析

通过以上测试,团队分析性能数据,据此针对性进行优化, 例如通过清理CPU 日志数据库存储调优等方式进行优化,以提高系统稳定性,优化结果如下所示:

测试指标

优化前

优化后

每秒事务处理能力

28000

45000

平均响应时间

6秒

0.2秒

最大响应时间

13秒

1秒

CPU使用率

99%

70%

内存使用率

97%

80%

根据性能测试结果,我们发现系统在负载和容量测试场景下呈现出问题

负载测试:

我们注意到在高负荷下,响应时间开始大幅上升并且响应时间的标准差开始下降。这表明系统正在达到其极限,并可能无法容忍更多的用户。

容量测试:

当我们在大负载下执行测试时,发现系统性能发生了很大的下降。我们发现jMeter本身不能支持如此大量的并发用户访问,我们使用了不同的工具来验证测试结果,我们发现系统极限在28000并发访问量左右。该结果使我们意识到系统还需要在某些方面进一步优化。

第五步:

得出结论——性能测试报告

通过各种性能测试方式,团队得出了一个详细的测试报告。该报告概括了测试结果及其优化方案,并包括了性能测试的详细数据、结论和建议,以便游戏开发团队根据测试结果决定是否更改系统架构、代码或参数。最终,该游戏系统在经过不断测试和改进后成功上线,并获得了良好的用户体验。

总结:

该高性能游戏系统性能测试案例中,测试团队首先制定了测试目标,确定测试计划,然后采用不同的测试工具进行测试,为改进系统性能提供了数据支持,并得出了详细的测试报告。测试结果中的异常分析让工程团队能够针对具体的问题进行精细的优化。这一成功性能测试的案例展示出一个优秀公司如何在高压力的环境下验证性能、保证高可用性和安全性,实现巨大价值的过程。

感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/31 19:30:19

为什么我坚持用git命令行,而不是GUI工具?

上周,我们组里来了个新同事,看我噼里啪啦地在黑窗口里敲git命令,他很好奇地问我:“哥,现在VS Code自带的Git工具那么好用,还有Sourcetree、GitKraken这些,你为什么还坚持用命令行啊?…

作者头像 李华
网站建设 2026/3/28 19:06:38

白盒测试与黑盒测试【史上最全】

🍅 点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快本文介绍白盒测试与黑盒测试有关内容,并伴随例子讲解测试用例测试用例就是一个文档,描述输入、动作、或者时间和一个期望的结果,…

作者头像 李华
网站建设 2026/3/30 12:06:19

/var/run/php-fpm.sock = 127.0.0.1:9000?

不,/var/run/php-fpm.sock ≠ 127.0.0.1:9000。 二者是 PHP-FPM 与 Web 服务器通信的两种不同传输机制: /var/run/php-fpm.sock 是 Unix Domain Socket(UDS)127.0.0.1:9000 是 TCP Socket 虽然功能相同(传递 FastCGI 请…

作者头像 李华
网站建设 2026/3/29 23:21:27

虾皮Java面试被问:分布式Top K问题的解决方案

一、问题定义与挑战 1.1 问题定义 在分布式系统中,我们需要从海量数据(PB级别)中找出最大的K个元素或最小的K个元素。 python 复制 下载 class DistributedTopKProblem:"""分布式Top K问题定义"""def __in…

作者头像 李华