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

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

核心的关键词: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()  # 非阻塞IOreturn 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

  • 【Python】一直搞不懂迭代器是个啥。。-CSDN博客
  • 【Python】包了一个闭包,Python解释器偷偷干了什么-CSDN博客
  • 【Python|面试】import用了无数次,但你不知道它的一切……-CSDN博客
http://www.dtcms.com/a/192916.html

相关文章:

  • 第一天的尝试
  • iOS性能调优实践:我常用的工具与流程(含克魔 KeyMob 使用体验)
  • 【在qiankun模式下el-dropdown点击,浏览器报Failed to execute ‘getComputedStyle‘ on ‘Window‘: parameter 1 is not o
  • 矫平机深度解析:技术细节、行业应用与未来革新
  • set, multiset ,unordered_set; map, multimap, unordered_map
  • 本地部署Firecrawl+Dify调用踩坑记录
  • MySQL 8.0 OCP 1Z0-908 101-110题
  • C++delete详解剖析
  • 【测试】测试分类
  • 5月15日星期四今日早报简报微语报早读
  • 视频分辨率增强与自动补帧
  • 【.net core】.net core 6.0添加WCF服务引用
  • 沐渥氮气柜氧含量控制核心目标
  • RHCA笔记
  • pgsql14自动创建表分区
  • sqli-labs靶场第七关——文件导出注入
  • python 如何遍历 postgresql 所有的用户表 ?
  • PostgreSQL 联合索引生效条件
  • 每日Prompt:磨砂玻璃后的虚实对比剪影
  • 如何在WooCommerce中设置Stripe
  • 【匹配】Needleman–Wunsch
  • 【yolo】如何在 YOLOv8 中添加负样本以减少误检
  • Springboot3自定义starter笔记
  • MarkitDown:AI时代的文档转换利器
  • 四维时空数据安全传输新框架:压缩感知与几何驱动跳频
  • 【iOS安全】Dopamine越狱 iPhone X iOS 16.6 (20G75) | 解决Jailbreak failed with error
  • 如何在多线程环境下避免快速失败异常?
  • GPU异步执行漏洞攻防实战:从CUDA Stream竞争到安全编程规范
  • NHANES指标推荐:OBS
  • 大数据架构选型分析