news 2026/6/9 13:58:49

不同 QPS 场景下的服务部署架构指南(实战经验总结)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
不同 QPS 场景下的服务部署架构指南(实战经验总结)

高并发对于后端系统而言既是挑战,也是检验架构成熟度的重要指标。无论是推荐系统、API 网关、还是营销活动接口,只要涉及大量用户访问,就不可避免要面对QPS(Queries Per Second,每秒请求数)的极限问题。

这篇文章结合实际经验,从QPS 的计算原理 → 并发和 DAU 的关系 → 不同 QPS 的部署架构全面整理,形成一套可落地的服务性能扩展指南。


1. 什么是 QPS?怎么计算?

QPS 的定义非常简单:

QPS = 一段时间内处理的请求总数 ÷ 时间(秒)

举例:10 秒处理了 30000 个请求
→ QPS = 3000

压测工具(ab/wrk/JMeter)也会直接输出类似:

Requests per second: 2987.12

这就是 QPS。


2. QPS 与并发量(Concurrency)不是一回事

很多人容易混淆:

名称含义
并发数(Concurrency)同一时刻正在处理的请求数量
QPS每秒能完成多少个请求

两者之间的大致关系:

QPS ≈ 并发数 / 平均响应时间 RT(秒)

例如:

  • 并发 1000
  • 平均响应时间 0.2 秒

则 QPS ≈ 1000 / 0.2 =5000

这意味着如果想提升 QPS,提高并发能力和降低 RT 两者缺一不可。


3. DAU 与并发的经验映射(行业标准)

互联网行业中有非常稳定的统计规律:

峰值并发 ≈ DAU × 0.01% ~ 0.1%

典型推荐系统(首页推荐、详情页推荐)通常是:

并发 ≈ DAU × 0.03% ~ 0.08%

对照表如下:

DAU峰值并发(典型)峰值 QPS(RT=200ms)
1 万3~815~40
10 万30~70150~350
50 万150~350750~1750
100 万300~6001500~3000

因此,一个系统想达到3000 QPS,通常需要100 万级 DAU


4. 不同 QPS 场景下的部署架构建议

以下提供不同 QPS 阶段的实战部署方案(尤其针对 Python Flask + Gunicorn + gevent + MySQL + Redis 的常见技术栈)。


⭐ 场景 1:QPS ≤ 100

适用于小业务 / 内部工具 / 测试环境。

推荐架构:

  • 机器:1 台 2C / 4G 或 2C / 8G

  • gunicorn:

    workers = 2 worker_class = "gevent" worker_connections = 200 timeout = 30
  • MySQL / Redis:可与应用共机

  • 监控:简单日志即可

几乎不用考虑扩展问题。


⭐ 场景 2:QPS 100~500

适用于小型线上推荐接口 / 省级运营商单入口业务。

推荐架构:

  • 应用:1 台 4C / 8G(建议双机部署)

  • gunicorn:

    workers = 4 worker_class = "gevent" worker_connections = 400 keepalive = 5 max_requests = 2000
  • MySQL:独立实例(读写同库即可)

  • Redis:单机版即可

  • 重点:优化 SQL,增加 Redis 缓存

此阶段可以靠单机支撑 QPS 300~400。


⭐ 场景 3:QPS 500~2000

适用于多入口调用的推荐平台,如 APP 首页、多个业务线共用接口。

核心策略:开始水平扩展 + 数据库拆分

应用层

  • 2~3 台 8C / 16G

  • 每台 gunicorn:

    workers = 6 worker_class = "gevent" worker_connections = 500 timeout = 30

数据层

  • MySQL 主从
  • 读写分离(读走从库)
  • Redis 主从或哨兵

架构优化

  • 用户画像缓存(Redis)
  • 召回结果缓存
  • 热度产品缓存
  • 推荐理由异步化(MQ)

此阶段是多数省级推荐系统的常态。


⭐ 场景 4:QPS 2000~5000

适用于省级统一推荐平台 / 多场景大流量并发。

推荐架构:

应用层(核心)
  • 4~8 台,8C / 16G(或 16C / 32G)

  • gunicorn:

    workers = 6~8 worker_class = "gevent" worker_connections = 800
服务拆分
  • user-profile-service(用户特征)
  • recall-service(ICF/UCF/热度/规则)
  • ranking-service(DeepFM/DNN)
  • reason-service(大模型理由生成,强制异步)
数据层
  • MySQL 分库分表
  • Redis Cluster
流控
  • 限流(用户级 / IP级)
  • 熔断(超时自动跳过某些服务)
  • 灰度发布

这是完整的省级推荐平台架构。


⭐ 场景 5:QPS 5000~10000+

适用于全国级推荐系统 / 多省统一调度 / 多业务大入口平台。

此时 Python 不一定适合作为主要承载层(更适合模型推理 / 特征服务)。

架构转型方向:

  • 高频服务切换为Go / Java
  • 引入服务网格(Istio/Envoy)
  • 多机房部署(容灾)
  • Redis Cluster + TiDB / ClickHouse
  • Kafka 全链路实时埋点
  • GRPC 服务化、流量动态调度

此档位已经是阿里 / 字节 / 腾讯级别架构。


5. 针对推荐系统的特别提示

推荐接口属于“组合型 IO 密集接口”

  • 查 Redis
  • 查 MySQL
  • 多路召回
  • 模型打分
  • 大模型推荐理由(如有)

因此单机 QPS 通常会比纯计算或 Hello World API 要低。

Flask + gevent 单机安全 QPS 通常为:

  • 4C 机器:200 ~ 400
  • 8C 机器:400 ~ 800

所有部署建议均基于这一现实情况。


6. 总结:如何为你的业务选择架构?

可以用一句话快速判断:

目标 QPS ÷ 单机安全 QPS(≈300~600)≈ 需要的机器数量

例如你目标是 QPS 2000:

  • 单机安全 QPS = 500
  • 需要机器 ≈ 2000 / 500 = 4 台(再 ×1.3 冗余)
  • → 5~6 台即可
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/7 4:10:05

基于固定旋转Gough-Stewart平台模型的六自由度调整数学模型设计与实现

5 固定旋转 Gough-Stewart 平台的数学模型,允许使用爱好伺服系统调整六个平行腿的长度,以实现平台的 6 自由度运动 该模型允许定义俯仰-横滚-偏航轨迹来模拟轨迹并确保伺服角度在允许的运动范围内模型经过参数化,允许用户定义基座和平台上的连…

作者头像 李华
网站建设 2026/6/8 9:17:49

Waymo数据集10Hz相机序列:时序分析中的关键挑战与突破

Waymo数据集10Hz相机序列:时序分析中的关键挑战与突破 【免费下载链接】waymo-open-dataset Waymo Open Dataset 项目地址: https://gitcode.com/gh_mirrors/wa/waymo-open-dataset Waymo Open Dataset作为自动驾驶领域的重要数据源,其端到端驾驶…

作者头像 李华
网站建设 2026/6/9 4:01:32

Intel Neural Compressor终极指南:掌握深度学习模型压缩技术

Intel Neural Compressor终极指南:掌握深度学习模型压缩技术 【免费下载链接】neural-compressor Provide unified APIs for SOTA model compression techniques, such as low precision (INT8/INT4/FP4/NF4) quantization, sparsity, pruning, and knowledge disti…

作者头像 李华
网站建设 2026/6/5 22:55:42

局域网服务发现技术:mDNS与DNS-SD实战

本文深入解析mDNS和DNS-SD协议原理,带你实现零配置的局域网服务自动发现。 前言 你有没有好奇过: 为什么iPhone能自动发现家里的AirPlay设备? 为什么Chromecast能被同一WiFi下的设备识别? 为什么NAS可以在文件管理器中自动显示? 这背后都是同一套技术:mDNS + DNS-SD,也…

作者头像 李华
网站建设 2026/6/5 15:32:32

kcat工具实战:3分钟构建企业级Kafka内存测试环境

kcat工具实战:3分钟构建企业级Kafka内存测试环境 【免费下载链接】kcat Generic command line non-JVM Apache Kafka producer and consumer 项目地址: https://gitcode.com/gh_mirrors/kc/kcat 在当今微服务架构盛行的时代,Kafka已成为消息系统的…

作者头像 李华