首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >FastAPI不异步运行

FastAPI不异步运行
EN

Stack Overflow用户
提问于 2019-10-14 15:30:56
回答 5查看 6.1K关注 0票数 12

我可能没有正确理解FastAPI中的异步概念。

我同时从两个客户端访问以下应用程序的根端点。我希望FastAPI在执行开始时连续两次打印Started

代码语言:javascript
复制
from fastapi import FastAPI
import asyncio

app = FastAPI()

@app.get("/")
async def read_root():
    print('Started')
    await asyncio.sleep(5)
    print('Finished')
    return {"Hello": "World"}

相反,我得到了以下内容,它看起来非常非异步:

代码语言:javascript
复制
Started
Finished
INFO: ('127.0.0.1', 49655) - "GET / HTTP/1.1" 200
Started
Finished
INFO: ('127.0.0.1', 49655) - "GET / HTTP/1.1" 200

我遗漏了什么?

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2020-03-05 16:06:16

如何确保同时存在多个请求?

您的代码很好--尝试使用以下命令进行测试:

代码语言:javascript
复制
for n in {1..5}; do curl http://localhost:8000/ & ; done

您的浏览器可能会将后续请求缓存到同一个URL。

票数 11
EN

Stack Overflow用户

发布于 2019-10-15 10:41:25

这个github问题展示的演示来看,这可能不是FastAPI的原因,而是运行请求的客户端。

票数 4
EN

Stack Overflow用户

发布于 2021-06-29 02:20:19

我在Chrome浏览器上做了同样的实验,结果和最初报道的一样。来自两个独立的Chrome浏览器的请求被一个接一个地处理(好像是连续的)。

代码语言:javascript
复制
@app.get("/test")
async def test():
    r = {"message": "Hello by /test api"}
    r['timestamp'] = datetime.datetime.utcnow()
    await asyncio.sleep(10)
    return r

两个请求花了20秒(每个10秒)完成整个过程,这显然不是一个并发的方式!

但是,当我按照答案中的建议尝试使用curl时,它被并行地处理(!)

我在两个Firefox浏览器上做了最后一次实验,结果也是并行执行。

最后,我从FastAPI的日志中找到了线索。当我尝试使用两个Chrome浏览器时,请求的来源(ip:port)被记录为相同

代码语言:javascript
复制
INFO:     10.10.62.106:54668 - "GET /test HTTP/1.1" 200 OK
INFO:     10.10.62.106:54668 - "GET /test HTTP/1.1" 200 OK

但是,如果我尝试使用Firefox,源代码就不一样了。

代码语言:javascript
复制
INFO:     10.10.62.106:54746 - "GET /test HTTP/1.1" 200 OK
INFO:     10.10.62.106:54748 - "GET /test HTTP/1.1" 200 OK

从上面的日志中,我可以得出结论,只有当源地址不同时,FastAPI (或前面的uvicorn )才并行处理请求。

请有人对上述结论提出评论。谢谢。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58379889

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档