2026/1/7 14:31:30
网站建设
项目流程
网站建设带主机,黑客软件资源网站,wordpress文学模版,用手机做服务器做网站#x1f345; 点击文末小卡片#xff0c;免费获取软件测试全套资料#xff0c;资料在手#xff0c;涨薪更快一、性能测试的概念定义#xff1a;软件的性能是软件的一种非功能特性#xff0c;它关注的不是软件是否能够完成特定的功能#xff0c;而是在完成该功能时展示出…点击文末小卡片免费获取软件测试全套资料资料在手涨薪更快一、性能测试的概念定义软件的性能是软件的一种非功能特性它关注的不是软件是否能够完成特定的功能而是在完成该功能时展示出来的及时性。由定义可知性能关注的是软件的非功能特性所以一般来说性能测试介入的时机是在功能测试完成之后。在系统基础功能测试验证完成、系统趋于稳定的情况下才会进行性能测试否则性能测试是无意义的。另外由定义中的及时性可知性能也是一种指标可以用时间或其它指标来衡量通常我们会使用某些工具或手段来检测软件的某些指标是否达到了要求这就是性能测试。性能测试定义指通过自动化的测试工具模拟多种正常、峰值以及异常负载条件来对系统的各项性能指标进行测试。二、性能测试类型基准测试在给系统施加较低压力时查看系统的运行状况并记录相关数做为基础参考负载测试是指对系统不断地增加压力或增加一定压力下的持续时间直到系统的某项或多项性能指标达到安全临界值不断加压使系统达到瓶颈为调优提供参考数据。压力测试1稳定性压力测试在不同的给定的条件下比如内存的使用一定时间段内有多少请求等系统表现出来的处理反应能力这里会考虑系统的容错能力恢复能力2破坏性压力测试不断加压直至系统崩溃挂掉来得出系统的最大承受能力在哪儿稳定性测试在给系统加载一定业务压力的情况下使系统运行一段时间以此检测系统是否稳定。并发测试测试多个用户同时访问同一个应用、同一个模块或者数据记录时是否存在死锁或者其他性能问题失效恢复测试针对有多余备份和负载均衡的系统设计,检测如果系统局部发生故障系统能否继续使用配置测试通过对被测系统软硬件环境的调整了解各种不同环境对系统性能影响的程度从而找到系统各项资源的最优分配原则三、性能测试应用场景领域性能测试应用场景领域主要有能力验证、规划能力、性能调优、缺陷发现、性能基准比较下表简单介绍和对比了这几个场景的各自用途和特点下表为性能测试应用领域与测试方法关联四、性能测试常用的指标1、响应时间Response Time定义从用户发送一个请求到用户接收到服务器返回的响应数据这段时间就是响应时间计算方法Response time 网络时间 应用程序处理时间合理的响应时间 2/5/10 2秒之内给客户响应被用户认为是非常有吸引力的5秒之内比较糟糕10秒之内糟糕的用户体验超过10秒请求失败响应时间-负载对应关系图中拐点说明1、响应时间突然增加2、意味着系统的一种或多种资源利用达到的极限3、通常可以利用拐点来进行性能测试分析与定位2、吞吐量定义单位时间内系统处理的客户端请求的数量计算方法Throughput (number of requests) / (total time)吞吐量-负载对应关系①上升阶段吞吐量随着负载的增加而增加吞吐量和负载成正比②平稳阶段吞吐量随着负载的增加而保持稳定无太大变化或波动③下降阶段吞吐量随着负载的增加而下降吞吐量和负载成反比a1面积越大说明系统的性能能力越强a2面积越大说明系统稳定性越好a3面积越大说明系统的容错能力越好吞吐率吞吐量/传输时间即单位时间内网络上传输的数据量也可以指单位时间内处理客户请求数量它是衡量网络性能的重要指标。通常情况下吞吐率用“字节数/秒”来衡量当然也可以用“请求数/秒”和“页面数/秒”来衡量3、并发数①狭义上的并发所有用户在同一时间点进行同样的操作一般指同一类型的业务场景比如1000个用户同时登陆系统②广义上的并发多个用户与系统发生了交互这些业务场景可以是相同的也可以是不同的交叉请求和处理较多4、资源利用率资源指标与硬件资源消耗直接相关而系统指标则与用户场景及需求直接相关资源指标CPU使用率指用户进程与系统进程消耗的CPU时间百分比长时间情况下一般可接受上限不超过85%内存利用率内存利用率1-空闲内存/总内存大小*100%一般至少有10%可用内存内存使用率可接受上限为85%磁盘I/O: 磁盘主要用于存取数据因此当说到IO操作的时候就会存在两种相对应的操作存数据的时候对应的是写IO操作取数据的时候对应的是是读IO操作一般使用% Disk Time磁盘用于读写操作所占用的时间百分比度量磁盘读写性能网络带宽一般使用计数器Bytes Total/sec来度量其表示为发送和接收字节的速率包括帧字符在内判断网络连接速度是否是瓶颈可以用该计数器的值和目前网络的带宽比较系统指标并发用户数单位时间内与系统发生交互的用户数在线用户数某段时间内访问系统的用户数这些用户并不一定同时向系统提交请求平均响应时间系统处理事务的响应时间的平均值事务的响应时间是从客户端提交访问请求到客户端接收到服务器响应所消耗的时间事务成功率性能测试中定义事务用于度量一个或者多个业务流程的性能指标如用户登录、保存订单、提交订单操作均可定义为事务单位时间内系统可以成功完成多少个定义的事务在一定程度上反应了系统的处理能力一般以事务成功率来度量超时错误率主要指事务由于超时或系统内部其它错误导致失败占总事务的比率资源利用-负载对应关系图中拐点说明1、服务器某件资源使用逐渐达到饱和2、通常可以利用拐点来进行性能测试分析与定位5、其它常用概念TPSTransaction Per Second每秒事务数指服务器在单位时间内秒可以处理的事务数量一般以request/second为单位QPS是查询而TPS是事务事务是查询的入口也包含其他类型的业务场景因此QPS应该是TPS的子集QPSQuery Per Second每秒查询率指服务器在单位时间内秒处理的查询请求速率TPS和QPS都是衡量系统处理能力的重要指标一般和并发结合起来判断系统的处理能力Thinking Time思考时间在性能测试中模拟用户的真实操作场景。用户操作的事务与事务之间是有一定间隔的此时间内是不对服务器产生压力的引入这个概念是为了并发测试有交叉业务场景时业务场景比率更符合真实业务场景PVPage View页面浏览量通常是衡量一个页面甚至网站流量的重要指标细分的话有独立访问者数量、重复访问者数量、单独页面访问数量、用户停留时间等类型RT/ARTResponse Time/average Response Time响应时间/平均响应时间指一个事务花费多长时间完成一般来说性能测试中平均响应时间更有代表意义。细分的话还有最小最大响应时间50%、90%用户响应时间等五、性能测试流程需求分析需要分析的系统信息需要分析的业务信息性能需求评估在实施性能测试之前我们需要对被测系统做相应的评估主要目的是明确是否需要做性能测试。如果确定需要做性能测试需要进一步确立性能测试点和指标明确该测什么、性能指标是多少测试通过or不通过的标准性能指标也会根据情况评估要求被测系统能满足将来一定时间段的业务压力。业务角度:系统是公司内部 or 对外系统使用的人数的多少系统角度a系统架构b数据库要求c系统特殊要求确定性能测试点关键业务确定被测项目是否属于关键业务有哪些主要的业务逻辑点特别是跟交易相关的功能点。例如转账扣款等接口。如果项目或功能点不属于关键业务或关键业务点日请求量确定被测项目各功能点的日请求量可以统计不同时间粒度下的请求量如小时日周月。如果日请求量很高系统压力很大而且又是关键业务该项目需要做性能测试而且关键业务点可以被确定为性能点逻辑复杂度判定被测项目各功能点的逻辑复杂度。如果一个主要业务的日请求量不高但是逻辑很复杂则也需要通过性能测试。原因是在分布式方式的调用中当某一个环节响应较慢就会影响到其它环节造成雪崩效应。运营推广活动根据运营的推广计划来判定待测系统未来的压力。未雨绸缪、防患于未然、降低运营风险是性能测试的主要目标。被测系统的性能不仅能满足当前压力更需要满足未来一定时间段内的压力。因此事先了解运营推广计划对性能点的制定有很大的作用。例如运营计划做活动要求系统每天能支撑多少 PV、多少 UV或者一个季度后需要能支撑多大的访问量等等数据。当新项目或功能点属于运营重点推广计划范畴之内则该项目或功能点也需要做性能测试。建立性能指标a.选取核心业务流程重要程度/频繁b.并发用户数c.事物吞吐需求d.响应时间需求e.系统占用资源需求f.可扩展性需求建立系统负载模型业务层面a核心业务流程吞吐率b高峰期业务分布时段系统负载a 高峰/平常场景吞吐率bCPU/IO/MEM/NETWORK数据来源a服务器端监控b数据库日志c用户提出需求制定测试计划的实施时间和方案预设本次性能测试各子模块的起止时间和结束时间测试环境的配置局域网虚拟机操纵系统数据库中间件参与人员谁负责哪些任务测试策略。产出测试方案分析结果六、搭建测试环境测试机环境执行机环境这个就是用来生成负载的执行机通常需要在物理机上运行。负载工具JDK/Eclipse/LoadRuner or Jmeter或Galting等监控工具准备性能测试时的服务器资源、JVM、数据库监控工具以便进行后续的性能测试分析与调优服务器环境系统运行环境这个通常就是我们的测试环境Linux系统/数据库/应用服务/各种监控工具。大部分公司的测试环境会低于生产环境同时还需要考虑到不同的硬件配置是否会是制约系统性能的重要因素因此在测试环境中需要部署多个不同的测试环境在不同的硬件配置上检查应用系统的性能配置大概是如下几类①数据库服务器②应用服务器③负载模拟器④软件运行环境平台并对不同配置下系统的测试结果进行分析得出最优结果最适合当前系统的配置测试场景设计通过和业务部门沟通以及以往用户操作习惯确定用户操作习惯模式以及不同的场景用户数量操作次数确定测试指标以及性能监控等七、测试用例设计和脚本开发选择LoadRuner或者Jmeter我使用的是Jmeter。我使用Jmeter的工具进行录制。(PS能直接写脚本就自己写尽量少录制录制有时候会有干扰)对脚本进行修改增强脚本让脚本更符合业务逻辑可用性更强。1参数化用户输入2关联数据3增加事物4增加检查点调试脚本1Vugen单次回放2Vugen多次回放3Controller单脚本多用户4Controller多脚本多用户5查看回放日志验证脚本1通过检查点验证2通过查看后台服务器日志验证3通过测试系统查看运行后台变化4利用SQL语句查询/插入/更新/修改查看效果八、测试数据准备获取数据有两种方式1拉取生产数据尽量保持数据一致以及量级足够2利用脚本自动生成数据或者利用测试工具生成数据如利用JDBC预埋数据a负载测试数据并发测试时需要多少数据比如登录场景bDB数据量大小为了尽量符合生产场景需要模拟线上大量数据情况那么要往数据库里提前插入一定的数据量。九、性能测试执行和管理执行测试脚本在已部署好的测试环境中按照业务场景和编号按顺序执行我们已经设计好的测试脚本测试结果记录根据测试采用的工具不同结果的记录也有不同的形式展现方式折线图统计图表格等现在大多的性能测试工具都提供比较完整的界面图形化的测试结果当然对于服务器的资源使用等情况可以利用一些计数器或第三方监控工具来对其进行记录执行完测试后对结果进行整理分析十、性能测试结果分析与调优测试环境的系统性能分析根据之前记录得到的测试结果经过计算与预定的性能指标进行对比确定是否达到了我们需要的结果如未达到查看具体的瓶颈点然后根据瓶颈点的具体数据瓶颈定位分析吞吐量二八原则 即80%的业务在20%的时间内完成/正太分布响应时间2/5/10原则内存磁盘IO进程网络分析硬件操作系统中间件应用瓶颈进行具体情况具体分析性能调优时间资源人力资源硬件资源扩展性影响硬件设备对系统性能表现的影响分析配置几个不同的测试环境故可以根据不同测试环境的硬件资源使用状况图进行分析确定瓶颈是再数据库服务器、应用服务器抑或其他方面然后针对性的进行优化等操作其他影响因素分析影响系统性能的因素很多可以从用户能感受到的场景分析哪里比较慢哪里速度尚可这里可以根据2\5\8原则对其进行分析至于其他诸如网络带宽、操作动作、存储池、线程实现、服务器处理机制等一系列的影响因素具体问题具体分析测试中发现的问题在性能测试执行过程中可能会发现某些功能上的不足或存在的缺陷以及需要优化的地方需要多次执行测试。十一、测试报告和跟踪性能测试报告是性能测试的里程碑通过报告能展示出性能测试的最终成果展示系统性能是否符合需求是否有性能隐患。性能测试报告中需要阐明性能测试目标、性能测试环境、性能测试数据构造规则、性能测试策略、性能测试结果、性能测试调优说明、性能测试过程中遇到的问题和解决办法等。性能测试工程师完成该次性能测试后需要将测试结果进行备案并做为下次性能测试的基线标准具体包括性能测试结果数据、性能测试瓶颈和调优方案等。同时需要将测试过程中遇到的问题包括代码瓶颈、配置项问题、数据问题和沟通问题以及解决办法或解决方案进行知识沉淀。最后感谢每一个认真阅读我文章的人礼尚往来总是要有的虽然不是什么很值钱的东西如果你用得到的话可以直接拿走这些资料对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库这个仓库也陪伴我走过了最艰难的路程希望也能帮助到你凡事要趁早特别是技术行业一定要提升技术功底。