接触过性能测试的小伙伴一定都听过响应时间(Response Time)、TPS、CPU资源利用率等术语,它们都属于性能测试的指标。本文对性能测试中涉及到的指标做了较为详细的整理。
性能测试指标一般可以分为系统性能指标、资源指标、应用指标:
- 系统性能指标:如并发用户数、TPS(系统每秒处理事务数)、成功率、响应时间。
- 资源指标:如CPU资源利用率、内存利用率、I/O、内核参数(信号量、打开文件数)等。
- 应用指标:如空闲线程数、数据库连接数、GC/FULL GC次数、函数耗时等。
1. 系统性能指标
1.1 响应时间(Response Time, RT)
指标说明
响应时间指用户从客户端发起一个请求开始,到客户端接收到从服务器端返回的响应结束,整个过程所耗费的时间。在性能测试中一般以压力发起端到被压测服务器返回处理结果的时间为计量,单位一般为毫秒。
平均响应时间指系统稳定运行时间段内,同一接口多次请求的平均响应时间。通常性能指标中的响应时间都是指平均响应时间。
如下图所示,以一个简单的客户端-服务器-数据库的应用架构来看,响应时间可以被分解为网络传输时间(N1+N2+N3+N4)和应用延迟时间(A1+A2+A3),而应用延迟时间又可以分解为数据库延迟时间(A2)和应用服务器延迟时间(A1+A3)。对响应时间进行分解使得我们能够更有效率得定位性能瓶颈。
Web应用的响应时间分解
参考标准
不同行业不同业务可接受的响应时间是不一样的,需要根据自身情况设定合适的符合用户使用