Django和Fastapi异步性能对比
突发奇想,我想验证一下Python的异步后端框架的并发能力.
目前主流的异步框架有Fastapi,Django和Tornado. 顺便我想对比一下它们的性能,但是考虑到Tornado自成一派没有遵循Asgi,没办法屏蔽服务器部分的代码效率,所以我打算只拿Fastapi和Django做下对比.
实验设计
运行设备: 4核8进程虚拟机
为了只比较框架的优劣,两个框架用都用gunicorn去部署.
分别对单进程和8个进程部署进行了测试.
每次测试执行20轮并发请求,每轮并发请求数分别按照单进程部署100,8进程部署500递增.
每个并发请求是请求服务器的一个本地文件来模拟查询.
最后统计RPS(每秒能处理响应数).
结果
这是单进程的并发结果
可以看到Fastapi明显要比Django的性能高. 单进程每秒能处理500~600个请求. Django是300~400.
为了测试并发的极限我在8个进程的服务上跑了最高1W的并发.结果如下:
可以看到Fastapi的最高每秒能处理2300+的请求, Django的话1500左右.
所以我个人强烈推荐Fastapi!!! 不光性能强悍,它的源代码也非常清晰简洁!
相关代码和数据
补充
参考了uvicorn官方文档, 有默认的并发数限制, --backlog <int> - Maximum number of connections to hold in backlog. Relevant for heavy incoming traffic. Default: 2048
所以我觉得并发2300+左右可能并没有达到fastapi的上限。
__EOF__

本文作者:侯佳奇的博客
本文链接:https://www.cnblogs.com/houjiaqi/p/18075976.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
本文链接:https://www.cnblogs.com/houjiaqi/p/18075976.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)