news 2026/5/4 6:54:34

不同 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/5/1 16:23:36

Ubuntu+搜狗输入法:程序员的高效中文输入方案

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个面向程序员的Ubuntu搜狗输入法优化配置指南应用,包含:1) 开发环境专用词库 2) 编程术语快捷输入 3) Markdown/代码注释模板 4) 终端输入优化方案 5)…

作者头像 李华
网站建设 2026/5/3 15:52:05

HG系列重负荷滑轨预压等级如何选型更适配设备?

很多自动化设备工程师在选HG系列重负荷滑轨时,都会纠结预压等级怎么选才合适——选松了怕刚性不够,选紧了又担心影响寿命。作为直线导轨生产厂家的专业合作经销商,深圳市海威机电有限公司(HIWIN授权经销商)的技术团队经…

作者头像 李华
网站建设 2026/4/28 18:18:24

好用的车联网时序数据库机构有哪些

车联网时序数据库行业分析:TDengine的技术优势与应用价值行业痛点分析在车联网时序数据库领域,当前面临着诸多技术挑战。随着车联网的快速发展,车辆产生的数据量呈爆炸式增长,数据的实时性、准确性和高并发处理能力成为关键需求。…

作者头像 李华
网站建设 2026/4/22 9:52:18

BiliFM:B站音频下载的终极解决方案

BiliFM:B站音频下载的终极解决方案 【免费下载链接】BiliFM 下载指定 B 站 UP 主全部或指定范围的音频,支持多种合集。A script to download all audios of the Bilibili uploader you love. 项目地址: https://gitcode.com/jingfelix/BiliFM 想要…

作者头像 李华
网站建设 2026/5/4 2:26:42

Linux也可以有图形化界面,手把手教你链接X11远程桌面

图形化介绍 Linux图形化界面(GUI)的发展可以说是一部开源软件与操作系统用户体验不断演进的历史。 图形界面需求的出现:早期的Unix和类Unix系统(包括最早的 Linux)全部是基于命令行的,用户只能通过终端输入…

作者头像 李华
网站建设 2026/4/22 0:09:07

汽车零部件企业如何通过OEE钻取分析实现降本增效?

在制造业的激烈竞争中,设备综合效率(OEE)已经成为衡量汽车零部件企业生产效能的核心指标。作为汽车产业链的基石,零部件生产效率的提升不仅关乎企业的成本控制,更直接影响整车厂的供应链稳定性。然而,许多汽…

作者头像 李华