+
80
-

uvicorn+fastapi如何实现异步多worker HTTP请求?

uvicorn+fastapi如何实现异步多worker HTTP请求?


网友回复

+
0
-

Uvicorn 是一个成熟的 Python WSGI 服务器,可以方便地管理和运行多个 worker 进程。

FastAPI 是一个现代化、快速且高性能的 Web 框架,用于构建 API。它是基于 Python 标准 typing 模块和 Pydantic 库构建的, 允许您利用 Python 3.6+ 的数据类型提示来定义 API 模型。

我们可以将 Uvicorn 作为 Gunicorn 的 worker,从而获得多进程并发处理请求的能力。

从 Uvicorn 0.12.0 版本开始,Uvicorn 内置了对多进程 worker 的支持。你可以直接使用 --workers 选项来启动多个进程。

fastapi脚本main.py

from fastapi import FastAPI

app = FastAPI()

@app.get("/massage")
async def massage(name: str):
    massage_message = f"嗲嗲的{name},来享受一下舒缓的按摩服务吧~"
    return {"message": massage_message}
使用方式如下:

uvicorn app.main:app --host 0.0.0.0 --port 8000 --workers 4

上面的命令将启动 4 个 Uvicorn worker 进程,绑定到 0.0.0.0:8000 上。FastAPI 应用本身是无状态的,所以不需要做任何特殊处理。每个 worker 进程都是独立运行的,可以并行处理请求。但是,如果你的应用涉及到状态管理(如使用内存缓存或数据库连接池等),你可能需要为每个 worker 进程创建单独的状态对象或连接池。否则,多个进程之间可能会发生资源竞争或数据不一致的问题。

我知道答案,我要回答