QPS、TPS、RPS 详解

QPS、TPS、RPS 详解

1. QPS(Queries Per Second,每秒查询率)
  • 定义:系统每秒处理的查询请求数量
  • 应用场景:数据库、搜索引擎等查询密集型系统
  • 计算公式
    QPS=总查询量统计时间(秒) \text{QPS} = \frac{\text{总查询量}}{\text{统计时间(秒)}} QPS=统计时间(秒)总查询量
  • 示例 :某数据库1分钟处理3600次查询,则:
    QPS=360060=60 \text{QPS} = \frac{3600}{60} = 60 QPS=603600=60
2. TPS(Transactions Per Second,每秒事务数)
  • 定义:系统每秒完成的事务处理数量
  • 核心特征
    • 事务需满足ACID特性(原子性、一致性、隔离性、持久性)
    • 一个事务可能包含多个操作(如数据库的增删改查组合)
  • 计算公式
    TPS=成功事务数统计时间(秒) \text{TPS} = \frac{\text{成功事务数}}{\text{统计时间(秒)}} TPS=统计时间(秒)成功事务数
  • 典型场景:支付系统、银行交易等需要事务完整性的场景
3. RPS(Requests Per Second,每秒请求数)
  • 定义:服务端每秒接收的客户端请求数量
  • 关键特性
    • 一个请求可能触发多个查询(RPS≤QPS\text{RPS} \leq \text{QPS}RPS≤QPS)
    • 与网络层性能强相关
  • 计算公式
    RPS=总请求数统计时间(秒) \text{RPS} = \frac{\text{总请求数}}{\text{统计时间(秒)}} RPS=统计时间(秒)总请求数
  • 应用场景:Web服务器、API网关等网络服务

三者的关系与区别

维度 QPS TPS RPS
度量对象 查询操作 完整事务 网络请求
粒度 单次操作 多操作组合 单次请求
典型场景 MySQL查询 银行转账 HTTP请求
数值关系 RPS≤QPS\text{RPS} \leq \text{QPS}RPS≤QPS TPS≤RPS\text{TPS} \leq \text{RPS}TPS≤RPS 基础请求量

性能优化要点

  1. QPS提升

    • 优化索引结构
    • 查询语句精简
    • 结果缓存机制
  2. TPS提升

    • 事务拆分(减小事务粒度)
    • 异步提交机制
    • 分布式事务优化
  3. RPS提升

    • 负载均衡配置
    • 连接复用(如HTTP Keep-Alive)
    • CDN加速静态资源

:实际系统中三者常联动使用。例如电商下单场景:1个RPS(HTTP请求)→ 触发3个QPS(库存查询/订单创建/支付)→ 组成1个TPS(完整订单事务)。

相关推荐
极阴岛传人18 小时前
jmeter集群压测配置方法和注意事项
jmeter
keke_俩个科18 小时前
实战派 JMeter 指南:核心功能、并发压测实操与常见问题解决方案
java·jmeter·spring·spring cloud·tomcat
让世界再也没有bug3 天前
JMeter与Postman的区别
测试工具·jmeter·postman
IDOlaoluo3 天前
JMeterPlugins-Standard-1.4.0.zip 怎么安装?JMeter插件安装步骤详解
jmeter
oh-pinpin3 天前
【jmeter】-安装-插件安装
jmeter
qq_316837753 天前
jmeter 使用汇总报告查看吞吐量(QPS) 总在一个低数值上不去的解决办法
jmeter
克里斯蒂亚诺·罗纳尔达3 天前
jmeter内存踩坑记录
jmeter
杨梅树3 天前
jmeter的安装
jmeter
张永清-老清3 天前
图书出版的幕后故事-《JMeter核心技术、性能测试与性能分析》背后不为人知的事
jmeter·性能优化·性能调优·jmeter性能测试·性能分析·每周读书与学习
qq_316837754 天前
jmeter 分布式压测
分布式·jmeter