惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
V
Vulnerabilities – Threatpost
有赞技术团队
有赞技术团队
小众软件
小众软件
O
OpenAI News
C
Cyber Attacks, Cyber Crime and Cyber Security
I
Intezer
NISL@THU
NISL@THU
D
Darknet – Hacking Tools, Hacker News & Cyber Security
N
News and Events Feed by Topic
MongoDB | Blog
MongoDB | Blog
阮一峰的网络日志
阮一峰的网络日志
Hacker News: Ask HN
Hacker News: Ask HN
D
Docker
WordPress大学
WordPress大学
Security Archives - TechRepublic
Security Archives - TechRepublic
A
About on SuperTechFans
Stack Overflow Blog
Stack Overflow Blog
C
CERT Recently Published Vulnerability Notes
L
LINUX DO - 最新话题
Application and Cybersecurity Blog
Application and Cybersecurity Blog
M
MIT News - Artificial intelligence
Blog — PlanetScale
Blog — PlanetScale
S
Security @ Cisco Blogs
Cloudbric
Cloudbric
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
V
V2EX
Hacker News - Newest:
Hacker News - Newest: "LLM"
G
Google Developers Blog
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
W
WeLiveSecurity
Google DeepMind News
Google DeepMind News
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
H
Hackread – Cybersecurity News, Data Breaches, AI and More
G
GRAHAM CLULEY
S
Schneier on Security
T
Tor Project blog
Spread Privacy
Spread Privacy
PCI Perspectives
PCI Perspectives
Microsoft Security Blog
Microsoft Security Blog
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
F
Fortinet All Blogs
L
Lohrmann on Cybersecurity
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
T
The Exploit Database - CXSecurity.com
TaoSecurity Blog
TaoSecurity Blog
Apple Machine Learning Research
Apple Machine Learning Research
T
Threat Research - Cisco Blogs
T
Troy Hunt's Blog
罗磊的独立博客

博客园_首页

Plist 二进制格式 Milvus 和 PGVector,哪个更好? OpenClaw 已过时?在 VS Code 中运行 Hermes Agent! 第30篇文章:一个大三计科生的自白 Manim如何在数学公式中完美显示中文? Docker 部署 RocketMQ 5 并发编程核心概念辨析 C#事务处理最佳实践:别再让“主表存了、明细丢了”的破事发生 CLI 是什么?为什么大厂突然集体卷命令行? 【从0到1构建一个ClaudeAgent】协作-自主Agent UIImageView 设置图片不生效的原因排查 最小二乘问题详解20:无先验约束下的增量式SFM自由网平差 痞子衡嵌入式:大话双核i.MXRT1180之XIP应用里借助MU实现可靠Flash IAP的方法 AI Chat 封装, SemanticKerne.AiProvider.Unified 已发布 Windows下右键编辑js文件无法打开记事本——在注册表中使用环境变量 在后台服务中使用 Scoped 服务,为什么总是报错? H200 安装驱动并使用sglang启动模型 wireshark 抓包Trap上报告警内容 我用 AI 辅助开发了一系列小工具(2):图片压缩工具 [A Primer On MC and CC] 2.1 Memory Consistency 1 - 指令重排序和 SC 模型 Oracle数据库SCN推进技术详解与实践指南 玩转控件:封装个带图片的Label控件 Claude Code 4.7 真正该升级的不是模型,而是你的工作流 前端小白一句话,AI 帮我做了个颜值拉满的桌面媒体播放器。当代码不再是门槛,一句话编程就是现实。 5. WorkBuddy: 小龙虾的灵魂三件套,让你的小龙虾不只是工具 SQLite 分片方案实战:三种分片策略的深度对比 告别简陋 UI!一款基于 Fluent Design 和基于 WinUI 的开源免费、现代化的 Avalonia UI 控件库 关于二进制排列组合枚举的总结 AI开发-python-LangGraph框架(3-27-LangGraph从零实现大模型智能决策工作流) ElasticSearch主分片和副本分片概念详解 【002】HTTPS 粗解:证书、TLS 握手与对后端配置的影响 Hermes Agent 一周暴涨五万 Star,但我劝你别急着追 明明连接的是Redis的DB0,为什么能查到DB3的数据? 【从0到1构建一个ClaudeAgent】协作-Agent团队 熟悉电子元器件之后,电子小白下一步该怎么走? MAF快速入门(23)通过C#类定义Skills .NET 高级开发 | 手写一个对象映射框架 FastAPI数据库ORM怎么选?我肝了三个Demo后,终于不再纠结了 mysqldump 参数拾遗:在遗忘与铭记之间 C# .NET 周刊|2026年3月5期 Claude code入门 - 陈彦斌 一文学习入门 ThingsBoard 开源物联网平台 GitHub 热门项目 | 2026年04月16日 如何为GIT设置全局勾子,为每次提交追加信息 Number.isFinite和isFinite与isNaN()和Number.isNaN的区别 PortSwigger SQL注入LAB2 推荐一个测试人必备的Skills,从功能到性能全搞定(附详细实操和安装下载方式) 筑基期:掌握Odoo基础核心知识点02(Odoo XML 开发方式详解) GLM模型这么火,咱们用vllm也咧一个呗! 深入理解 AbortController:从底层原理到跨语言设计哲学 字符串学习笔记 多租户系统框架的基础模块设计和分析设计 Apache SeaTunnel Zeta 为什么能做到“又快又稳”? AI开发-python-LangGraph框架(3-26-LangGraph基本概念及第一个简单样例) Vue 3 组件通信,别只会用 Props 和 Emits 了,这几个狠活儿你得看看 ElasticSearch7.X版本配置密码 用Manim实现动态交点计算--从一个动点问题说起 团结引擎+Addressable+Instant Game打包抖音小游戏 function call 实战:让 LLM 自动判断 pod 异常、调用日志工具并完成故障分析 bubseek —— 让 Agent 的足迹,变成团队的洞察 通过 C# 读取并导出 PDF 书签 如何用 GitHub Actions 实现 Steam 自动化发布 【从0到1构建一个ClaudeAgent】并发-后台任务 .NET 高级开发 | 定制 ASP.NET Core 框架 电子小白:什么是运算放大器(运放) zero2Agent:面向大厂面试的 Agent 工程教程,从概念到生产的完整学习路线 堆上的ORW HC32F460 USB CDC通信异常:非对齐访问异常排查 20260413-Hyperbridge 攻击事件:发生在默克尔山上的验证绕过 那些喊着AI 要淘汰你的人,正在靠你的焦虑赚大钱! 深度学习进阶(八)Swin Transformer 最小二乘问题详解19:带先验约束的增量式SFM优化与实现 SnapTranslate 3.0 正式发布:全局划词翻译 + 完整英语学习闭环,一站式搞定查词、记词、复习 工作的意义、工作的困难认知再思考 .NET + AI 进阶实战:基于类的技能开发 - 打造可治理的 Agent 能力模块 【从0到1构建一个ClaudeAgent】规划与协调-技能 上周热点回顾(4.6-4.12) 电子小白的工具三件套:面包板、杜邦线、万能板 单表五亿数据的查询优化 | Mysql、StarRocks 2. WorkBuddy:从“我是谁”到“帮我干活” C# 如何减少代码运行时间:7 个实战技巧 基于HelixToolkit.SharpDX 渲染3D模型 - 笺上知微 从零开始的双臂具身VLA起源及现阶段发展综述 - SkyXZ 记对 xonsh shell 的使用, 脚本编写, 迁移及调优 - pluvium27 受够了Vibe Coding的失控?换个起点,让AI事半功倍 从开始配置漏洞环境到漏洞复现流程 - 難しい 关于10年工作经验的程序员对OpenClaw的实战经验分享以及看法 - 虚无境 Any metadata 的内存布局 C# .NET 周刊|2026年3月2期 - InCerry 我帮你测过了,测试圈排名第二的 Skill 依然很牛逼 Skill Discovery | 无监督技能发现的经典工作总结 - MoonOut 上下文工程是什么?过时了么?一文讲明白! - 一枫说码 开了 TUN 模式还是直连?90% 的人都踩过这个坑 AScript扩展多种脚本语言 - rockey627 AI 学习笔记:Agent 的记忆机制 你能被装进一个文件里吗?——7 万人把同事"蒸馏"成了 AI - 我没有三颗心脏 Claude Code 通关手册(七):给 AI 装上技能包——Skills 完全指南 - 暮色之狐 在浏览器中快速编辑代码:VSCode Web 集成实践 - Newbe36524 蒸馏自己 skill?基于 Deepseek 的蒸馏器,丐版蒸馏方式,简单便捷 - To_Carpe_Diem Spring AI Aliababa和AgentScope,哪个更好? - 苏三说技术
Uvicorn、Gunicorn 傻傻分不清?FastAPI 生产部署避坑指南
一名程序媛呀 · 2026-06-25 · via 博客园_首页

摘要:你是不是也遇到过 FastAPI 应用一上量就卡死、502 频发?这篇来自程序媛老友的经验之谈,不讲天书,只给你最落地的 ASGI/WSGI 服务器选型指南、配置参数详解和 Docker、Linux 部署实例。哪怕你只懂一点后端,跟着做也能搞出一个稳建的生产环境。

🎯 开头就是暴击:为什么我的 FastAPI 一上生产就跪?

你有没有过这种崩溃瞬间 —— 笔记本上 uvicorn main:app --reload 跑得行云流水,接口响应快到飞起。
结果兴冲冲部署到服务器,并发量刚一上来,请求就开始排队,然后 502、504 哗啦啦地来,用户群里瞬间炸锅。

别问我怎么知道的,那种滋味,真不想你再尝一遍。

所以今天这篇,我打算把 UvicornGunicorn 这些名字绕口的家伙,用你最听得懂的方式盘一遍,再给你一套拿来就能用的部署配置。

👩‍💻我是爱折腾的一名程序媛,喜欢研究全栈开发的各种实践,热爱分享踩坑后的收获与思考,也享受用代码写出各种实用小工具解决问题的快乐。

如果你也在技术这条路上向前走,关注我,愿我们能彼此陪伴,一起成为更好的自己 🌱

📌 本文能帮你解决什么

🔹 搞清楚 Uvicorn、Gunicorn、WSGI、ASGI 到底谁是谁的谁

🔹 知道什么时候用 uvicorn --workers,什么时候必须上 Gunicorn

🔹 拿到生产级 Gunicorn + Uvicorn 的配置样板

🔹 避开端口冲突、超时、僵尸进程等常见大坑

🔹 学会不同环境(开发、Docker、Linux 生产)的部署套路

🧠 核心原理:别把“饭店伙计”当成“饭店老板”

很多人刚接触部署,以为 uvicorn 就是一个完整的 Web Server,其实它更像一个跑得很快的伙计,能端菜(处理请求),但不会管理后厨的人手。

咱们打个比方,你的 FastAPI 应用是一家网红餐厅:

🔹 Uvicorn
是手脚麻利的服务员,接单上菜特别快,尤其是对需要等一会的菜(异步请求),它能先去招呼别桌,不会傻站着。

🔹 Gunicorn
是店长,它自己不端盘子,但它管着一群服务员,规定谁干活、干多少活、干累了换班、出了错重启。

🔹 Nginx
是门口的大堂经理,负责迎客、分流、挡掉捣乱的人。


那 WSGI 和 ASGI 呢?就是服务员和后厨的沟通协议。

🔹 WSGI 是同步的,一次只端一个菜。

🔹 ASGI 是异步的,适合同时处理好几桌的点单,FastAPI 天生就讲 ASGI 语。

好,现在你肯定想问:那 Uvicorn 自己不是也有 --workers 参数吗?直接用不就行了?接下来重点来了。

⚡ 实战对比:直接裸奔 vs 工头带队

🐍 方案一:直接 uvicorn --workers 4

确实,Uvicorn 支持多 worker,但这个“多”是靠它自己 fork 出来的,没有 Gunicorn 那么老练。实际跑起来,你会发现:

🔹 某个 worker 悄悄死掉,它不一定能拉起来。

🔹 内存占用管理比较糙。

🔹 信号处理和优雅关机,偶尔就闹脾气。

这里有一点要特别注意,如果你在 Windows 上开发,--workers 根本不能用!
你只能老老实实开多个进程,用端口转发,巨麻烦。所以 Windows 上只建议跑单 worker 做调试。

🛡️ 方案二:Gunicorn + UvicornWorker(生产首选)

这才是正经的生产之道。用 Gunicorn 来管理多个 Uvicorn worker 进程,每个 worker 依然使用 ASGI 协议,稳得一批。

命令长这样:

gunicorn main:app -w 4 -k uvicorn.workers.UvicornWorker --bind 0.0.0.0:8000

🔹 -w 4:开 4 个 worker 进程。

🔹 -k uvicorn.workers.UvicornWorker:指定干活的是 Uvicorn 的 worker 类,而不是默认的同步 WSGI worker。

🔹 --bind:监听所有网络接口的 8000 端口。

根据我以往的经验,worker 数设为 CPU 核心数 × 2 + 1 是个比较稳的开局,后期看负载再调。
一味开多,上下文切换反而会拖慢整体。


再说个容易翻车的点:超时时间

默认 Gunicorn 的 worker 超时只有 30 秒。
如果你的某个接口处理慢,比如生成报表要 1 分钟,那 Gunicorn 会直接杀掉 worker,用户那头就是 502。

务必在启动时加上 --timeout 120 或者更合适的值。

🐳 不同环境的落地姿势

💻 开发环境

追求快和热重载,单进程 Uvicorn 就是最佳答案:

uvicorn main:app --reload --host 0.0.0.0 --port 8000

千万别在 --reload 时加 --workers,你会收获一堆僵尸进程和莫名其妙的文件监控错误。

🚢 Docker 单容器部署

很多人在这里踩坑:容器里起了 Gunicorn,前面要不要再套 Nginx?

如果单机跑,且只在容器内用一个进程,Gunicorn 足够。
但更推荐 Nginx + Gunicorn 分开,用 docker-compose

Gunicorn 的 --bind 0.0.0.0:8000 后面让 Nginx 做反向代理,处理静态文件和限流。

一个小而美的 Dockerfile 片段:

CMD ["gunicorn""main:app""-w""4""-k""uvicorn.workers.UvicornWorker""--bind""0.0.0.0:8000"]

🏭 Linux 生产物理机

配合 systemdsupervisor 做进程守护,让 Gunicorn 自己做个乖孩子。

把上面那条命令写进启动脚本,让系统帮你盯着,挂了自动拉起来。

🚨 常见翻车现场及抢救

🔹 启动报端口占用
大概率是上个进程没死干净,lsof -i :8000 查出来 kill 掉。

🔹 静态文件 404
Gunicorn/Uvicorn 就别伺候静态文件了,丢给 Nginx,性能能翻好几倍。

🔹 WebSocket 连不上
如果前面套了 Nginx,记得升级 proxy_set_header UpgradeConnection "upgrade" 配置,不然 WebSocket 握手直接断。

🔹 日志里全是 worker timeout
检查你是不是有个接口偷偷同步调了个耗时的第三方库,把代码改成 async 搭配异步请求库。

💬 最后啰嗦一句

工具的选择上,我认为顺手的才是最好的!Uvicorn + Gunicorn 这对组合我认为是最稳的。
你不用迷信它们,但一定要理解背后“异步处理 + 进程管理”的思想,这样换成 Hypercorn、Daphne 也能一通百通。


把这篇文章保存起来吧,下次半夜被报警电话吵醒的时候,说不定靠这里面的某一句话就能多睡一小时。
如果觉得有用,点赞收藏加个关注,转发给那个还在和 502 死磕的朋友,咱们的技术路,一起少掉两根头发 🎯。