性能测试常见风险以及消减措施

本文涉及的产品
性能测试 PTS,5000VUM额度
简介: 性能测试常见风险以及消减措施

大家好,我是阿萨。性能测试过程中会遇到各种各样的风险,常见风险以及消减措施有哪些?


一: 时间


一)时间相关风险


时间相关风险不仅限于最终用户满意度,尽管这是大多数人首先想到的。时间也是某些与业务和数据相关的风险因素。性能测试可以解决的最常见的时间相关风险包括:


1. 应用程序是否够快以满足最终用户?


2.业务是否能够在数据过时之前处理和利用应用程序收集的数据?(例如,月末报告应在月底最后一天营业后24小时内完成,但应用程序需要48小时来处理数据。)


3. 应用程序是否能够向其用户呈现最新的信息(例如,股票报价)?


4. Web服务是否在抛出错误之前响应了最大预期响应时间?


二)缓解时间相关风险的策略


以下策略在缓解速度相关风险方面很有价值:


1.确保您的性能要求和目标代表您的用户的需求和愿望,而不是其他人的需求和愿望。


2.将您的速度测量结果与以前的版本和竞争对手的应用程序进行比较。


3.设计可以在正常和预期峰值时段复制实际工作负载的负载测试。


4.在实际生产期间与业务操作中使用的类似数据类型、分布和体量进行性能测试(例如,产品数量、待定订单状态的订单数量、用户基数的大小)。您可以在负载测试执行之前允许数据在数据库和文件服务器中累积,或者额外创建数据量。


5.使用性能测试结果帮助利益相关者做出明智的架构和业务决策。


6.在系统处于预期最大负载时,征求代表用户对系统满意度的反馈。


7. 在您的性能测试中包括时间关键事物。


8. 确保至少有一些性能测试是在定期系统进程执行时进行的(例如,下载定义更新或每周备份期间)。


9. 在各种条件、负载级别和场景组合下测量速度。(用户重视稳定的速度。)


10. 验证在您的性能测试期间显示和保存了所有正确的数据。(例如,用户更新信息,但确认屏幕仍显示旧信息,因为事务尚未完成写入数据库。)


二:可扩展性


一)扩展性相关风险


扩展性风险不仅涉及应用程序可以支持的用户数量,还涉及应用程序可以包含和处理的数据量,以及识别应用程序何时接近容量的能力。性能测试可以解决的常见扩展性风险包括:


1. 应用程序是否可以为 所有 用户基数提供一致和可接受的响应时间?


2. 应用程序是否可以存储在应用程序生命周期内收集的所有数据?


3. 是否有警告迹象表明应用程序即将达到最大容量?


4. 在高强度使用下,应用程序是否仍然安全?


5. 在高强度使用下,功能是否会受到损害?


6. 应用程序是否能够承受意外的峰值负载?


二)缓解扩展性相关风险的策略


以下策略在缓解扩展性相关风险方面很有价值:


1. 比较在各种负载下测量的速度。(请记住,最终用户不知道或不在乎其他人在同一时间使用应用程序的人数。)


2. 设计可以在正常和预期峰值时段复制实际工作负载的负载测试。


3. 在实际生产期间与业务操作中使用的类似数据类型、分布和体量进行性能测试(例如,产品数量、待定订单状态的订单数量、用户基数的大小)。您可以在负载测试执行之前允许数据在数据库和文件服务器中累积,或者额外创建数据量。


4. 使用性能测试结果帮助利益相关者做出明智的架构和业务决策。


5. 与更有意义的性能测试合作,这些测试映射到现实世界的要求。


6. 当您找到扩展性限制时,逐渐减少负载并重新测试,以帮助您识别可作为您及时采取对策的可靠指标的指标。


7.通过检查在各种负载下创建的数据库条目或验证对特定用户请求的响应返回的内容来验证应用程序的功能准确性。


8.进行超出预期峰值负载的性能测试,并通过让代表性用户和利益相关者在性能测试期间和之后手动访问应用程序来观察行为。


三: 稳定性


一)稳定性相关风险


稳定性是一个总括术语,涵盖可靠性、正常运行时间和恢复性等方面。尽管稳定性风险通常通过高负载、耐久性和压力测试得到解决,但稳定性问题有时也会在最基本的性能测试中检测到。性能测试可以解决的一些常见稳定性风险包括:


1. 应用程序是否可以长时间运行而不会数据损坏、减速或服务器需要重启?


2. 如果应用程序意外关闭,部分完成的事务会发生什么?


3.当应用程序在计划内或计划外停机后重新上线时,用户是否仍然能够看到/做他们期望的一切?


4. 当应用程序在非计划停机后重新上线时,它是否在正确的点上恢复?特别是,它是否不会尝试恢复已取消的事务?


5. 错误或重复的功能错误组合会导致系统崩溃吗?


6.是否有任何事务会导致系统范围的副作用?

负载平衡环境的一条腿是否可以关闭而仍然为用户提供不间断的服务?


7.系统是否可以在不关闭的情况下打补丁或更新?


二)缓解稳定性相关风险的策略


以下策略在缓解稳定性相关风险方面很有价值:


1. 为现实的耐久性测试留出时间。


2. 使用关键场景进行压力测试。使用关键性能指标(网络、磁盘、处理器、内存)和业务指标(丢失的订单数量、用户登录失败等)。


3. 与实际生产环境中的类似业务操作一起进行压力测试(例如,产品数量、待定订单状态的订单数量、用户基数的大小)。您可以在压力测试执行之前允许数据在数据库和文件服务器中累积,或者额外创建数据量。这将允许您复制关键错误,例如数据库或应用程序死锁以及其他压力故障模式。


4. 在测试期间关闭一台服务器,并观察剩余系统的功能、性能和数据完整性行为。


5.在系统重新启动之前和之后立即执行相同的测试。比较结果。您可以对服务或进程的循环使用相同的方法。


6. 在您的性能测试方案中包括错误或异常案例(例如,用户试图使用不正确的凭据登录)。


7. 在性能测试期间打补丁系统。


8. 在性能测试期间强制备份。

相关实践学习
通过性能测试PTS对云服务器ECS进行规格选择与性能压测
本文为您介绍如何利用性能测试PTS对云服务器ECS进行规格选择与性能压测。
相关文章
|
8月前
|
敏捷开发 存储 测试技术
敏捷测试中的挑战和自动化风险
敏捷测试中的挑战和自动化风险
|
6月前
|
测试技术 持续交付
自动化测试的双刃剑:提升效率与隐藏的风险
【7月更文挑战第24天】自动化测试,作为现代软件开发过程中不可或缺的一环,旨在通过自动执行预编写的测试脚本来提高测试效率和准确性。然而,随着自动化程度的加深,它所带来的潜在风险也日益显现。本文将探讨自动化测试在加速软件发布周期的同时可能引入的问题,以及如何平衡其利弊,确保软件质量不受影响。
|
5月前
|
监控 测试技术
软件测试中的风险管理:如何避免潜在缺陷
【8月更文挑战第5天】在软件开发的生命周期中,测试阶段扮演着至关重要的角色。本文将深入探讨软件测试中的风险管理,包括风险识别、评估和缓解策略。我们将通过具体案例分析,揭示如何在早期阶段预防和减少潜在的软件缺陷,以及如何通过有效的测试计划和执行来保障产品质量。文章旨在为读者提供一套系统的风险管理框架,帮助他们在软件开发过程中识别和应对各种测试风险。
217 3
|
8月前
|
安全 数据挖掘 测试技术
深入探究软件测试中的风险分析与管理
【5月更文挑战第7天】 在软件开发生命周期中,风险分析与管理是确保产品质量和项目成功的关键步骤。本文将探讨软件测试过程中如何有效进行风险评估、分类及采取相应的缓解措施。文章首先介绍了风险管理的重要性,然后详细阐述了风险识别的技术和工具,接着分析了如何制定和实施风险应对策略。最后,通过案例研究展示了一个结构化风险分析流程的实施效果。
204 2
|
测试技术
如何评估软件测试的质量风险?记住这5个核心关键点
如何评估软件测试的质量风险?记住这5个核心关键点
338 0
|
8月前
|
监控 安全 测试技术
测试管理中的风险分析
测试管理中的风险分析
106 0
测试管理中的风险分析
|
测试技术 程序员 开发工具
嵌入式软件测试笔记7 | 嵌入式软件测试中基于风险的测试策略如何开展?
嵌入式软件测试笔记7 | 嵌入式软件测试中基于风险的测试策略如何开展?
134 0
|
Python
FRM-市场风险-测试题1--python
FRM-市场风险-测试题1--python
94 0
|
人工智能 大数据 云计算
测试-风险甄别
测试-风险甄别