当前位置: 首页 > web >正文

QPS 和 TPS 详解

QPSTPS 是性能测试中的两个核心指标,用于衡量系统的吞吐能力,但关注点不同。以下是具体解析:


1. QPS(Queries Per Second)

定义:每秒查询数,表示系统每秒能处理的请求数量(无论请求是否成功)。
适用场景

  • Web服务:如API接口、HTTP请求。
  • 缓存/数据库:如Redis的GET/SET操作。

计算公式

QPS = 总请求数 / 测试时间(秒)

示例

  • 一个HTTP接口在10秒内收到5000次请求,则 QPS = 5000 / 10 = 500

2. TPS(Transactions Per Second)

定义:每秒事务数,表示系统每秒能完成的事务数量(一个事务可能包含多个请求)。
适用场景

  • 业务链路的性能:如支付流程(包含下单、支付、通知等多个步骤)。
  • 数据库事务:如银行转账(扣款+入款需保证原子性)。

计算公式

TPS = 成功的事务数 / 测试时间(秒)

示例

  • 一个支付流程(包含3个API调用)在1分钟内完成1200笔交易,则 TPS = 1200 / 60 = 20

3. QPS 和 TPS 的关系

对比维度QPSTPS
粒度单次请求完整业务流(可能含多请求)
成功要求统计所有请求(含失败)仅统计成功完成的事务
典型场景接口压测、缓存性能测试支付、订单等业务场景

常见关联

  • 若一个事务包含N个请求,则 QPS ≈ TPS × N(假设无失败请求)。
  • 例如:支付事务包含3个API调用(下单、支付、回调),当TPS=100时,QPS可能接近300。

4. 实际应用示例

性能测试报告中的体现

**电商系统压测结果**  
- **QPS(接口层)**:订单查询API达到 1200 QPS(单接口请求)。  
- **TPS(业务层)**:下单支付全链路稳定在 200 TPS(含支付+库存扣减)。  
- **瓶颈分析**:当TPS > 200时,数据库CPU达到90%,需优化慢SQL。  

如何优化?

  • 提高QPS
    • 增加服务器实例(水平扩展)。
    • 使用缓存(如Redis减少数据库查询)。
  • 提高TPS
    • 优化事务逻辑(如异步处理非核心步骤)。
    • 数据库分库分表(降低单表压力)。

5. 面试常见问题

Q:为什么QPS高但TPS低?

  • 可能原因
    1. 事务包含复杂业务逻辑(如风控校验)。
    2. 数据库锁竞争(如秒杀场景)。
    3. 外部服务调用超时(如第三方支付接口)。

Q:如何设计压测脚本区分QPS和TPS?

  • JMeter示例
    • QPS:直接统计HTTP Request的吞吐量。
    • TPS:使用Transaction Controller将多个请求合并为一个事务。

6. 总结

  • QPS:关注请求吞吐量,适合接口级性能评估。
  • TPS:关注业务完整性,适合核心流程性能评估。
  • 测试开发价值
    • 在简历中明确区分两者(如“优化接口QPS从500提升至1200”)。
    • 分析QPS/TPS瓶颈能体现你的深度性能调优能力
http://www.xdnf.cn/news/10017.html

相关文章:

  • 竞争加剧,美团的战略升维:反内卷、科技与全球化
  • C++ 游戏开发详细流程
  • 大规模JSON反序列化性能优化实战:Jackson vs FastJSON深度对比与定制化改造
  • Elasticsearch 分析器介绍
  • Camera相机人脸识别系列专题分析之六:MTK ISP6S平台人脸识别fdnode流程FdNodeImp.cpp详解
  • Xamarin劝退之踩坑笔记
  • 苹果签名!
  • 数据清理的例子
  • 【仿生机器人】仿生机器人认知-情感系统架构设计报告
  • 【Java工程师面试全攻略】Day4:JVM原理与性能调优深度解析
  • 达梦数据库:同1台服务器如何启动不同版本的DMAP服务
  • 【Docker管理工具】部署Docker管理面板DweebUI
  • 思维革命:DeepSeek-R1-0528 如何用一次小更新颠覆大模型格局
  • 每日算法-250530
  • 企业级安全实践:SSL/TLS 加密与权限管理(二)
  • 支持功能安全ASIL-B的矩阵管理芯片IS32LT3365,助力ADB大灯系统轻松实现功能安全等级
  • Tailwind CSS 实战:基于 Kooboo 构建 AI 对话框页面(五):语音合成输出与交互增强
  • JVM 性能调优
  • Day40打卡 @浙大疏锦行
  • 低功耗架构突破:STM32H750 与 SD NAND (存储芯片)如何延长手环续航至 14 天
  • 使用vscode进行c/c++开发的时候,输出报错乱码、cpp文件本身乱码的问题解决
  • 外包项目交付后还能怎么加固?我用 Ipa Guard 给 iOS IPA 增加了一层保障
  • 数据库暴露--Get型注入攻击
  • C++?多态!!!
  • Git的简单介绍分析及常用使用方法
  • openppp2 -- 1.0.0.25225 优化多线接入运营商路由调配
  • 电路笔记(通信):CAN 仲裁机制(Arbitration Mechanism) 位级监视线与特性先占先得非破坏性仲裁
  • 【机器人】具身导航 VLN 最新论文汇总 | Vision-and-Language Navigation
  • 人工智能100问☞第37问:什么是扩散模型?
  • 【清晰教程】利用Git工具将本地项目push上传至GitHub仓库中