【Python】【面试凉经】Fastapi为什么Fast

#新星杯·14天创作挑战营·第11期#

核心的关键词:ASGI、原生异步、协程、uvloop、异步生态、Pydantic编译时生成校验代码、DI system预计算依赖树

@interviewer 00:32:49 FastAPI 它优越于其他一些主流web框架像 django或 flask 的这个点在哪里?
@我 00:33:00fastapi 就是说它的 fast 性能高在哪里?它就是采用了一个携程来提高它的速度,通过事件循环…

FastAPI 的性能优势主要来自三个核心设计:

  1. 原生异步支持(Native async)-> 基于ASGI标准(Asynchronous Server Gateway Interface),通过协程避免了线程切换开销
  2. 自动请求验证(Auto-validation)-> 使用 Pydantic 在编译时生成校验代码,比运行时解释快10倍+
  3. 依赖注入系统(DI system)-> 通过类型提示预计算依赖树,减少运行时反射成本

FastAPI 之所以在并发性能上显著优于 Flask,并不仅仅是简单地使用了 uvloop 或异步特性,而是从设计理念、架构到底层实现都围绕异步和高并发进行了深度优化。以下是关键差异点:


1. 原生异步支持 vs. 兼容性适配

  • FastAPI 从底层就是基于 ASGI (Asynchronous Server Gateway Interface) 设计的,原生支持 async/await,每个请求都可以在事件循环中非阻塞地处理。例如:
    @app.get("/")
    async def read_data():
        data = await db.query()  # 非阻塞IO
        return data
    
  • FlaskWSGI 框架,本质是同步的。即使通过 asynciogevent 实现异步,也是在同步基础上打补丁(如 flask-asyncgevent 的 monkey-patch),存在上下文切换开销。

2. 性能关键组件的深度优化

  • FastAPI 默认集成 uvicorn(基于 uvloophttptools):
    • uvloop 替换了 Python 原生事件循环,性能接近 Go 的 goroutine。
    • httptools 是 C 实现的 HTTP 解析器,比 Python 原生解析快数倍。
  • Flask 即使搭配 uvloop,仍需通过 asgiref 等适配层转换为 ASGI,额外开销不可避免。

3. 依赖注入与高效数据处理

  • FastAPI 的依赖注入系统原生支持异步,且自动处理 JSON 解析(基于 orjsonpydantic):
    @app.post("/items")
    async def create_item(item: Item):  # 自动异步解析和验证
        return item
    
  • Flask 的请求解析和响应序列化是同步的,即使使用异步扩展,也需要手动处理。

4. 并发模型与生态工具链

  • FastAPI 的整个生态链(如数据库驱动 asyncpg、HTTP 客户端 httpx)是为异步设计的,避免阻塞事件循环。
  • Flask 的生态大多为同步(如 SQLAlchemy 同步版、requests),异步需要额外适配(如 SQLAlchemy 2.0 的异步支持)。

总结:FastAPI 的优化矩阵

优化维度FastAPIFlask
协议ASGI(原生异步)WSGI(同步)
事件循环uvloop + httptools(C层优化)原生或兼容层(性能损耗)
依赖注入原生异步支持无或扩展实现
生态工具全异步生态(如 asyncpg)同步为主
JSON 处理orjson/pydantic(Rust/C加速)Python 原生

FastAPI 的高并发并非单一技术的结果,而是从协议、核心组件到生态的全栈异步设计。如果 Flask 想要达到同等性能,需要重写核心逻辑并迁移生态,这实际上就是重新实现了一个 FastAPI。

关于作者

  • CSDN 大三小白新手菜鸟咸鱼本科生长期更新强烈建议不要关注

作者的其他文章

Python

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Sonetto1999

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值