Python的ASGI Web 服务器之uvicorn

什么是uvicorn

官网https://www.uvicorn.org/

Uvicorn 是一个用于 Python 的 ASGI Web 服务器实现。

Until recently Python has lacked a minimal low-level server/application interface for async frameworks. The ASGI specification fills this gap, and means we’re now able to start building a common set of tooling usable across all async frameworks.
直到最近,Python 还缺少一个用于异步框架的最小底层服务器/应用程序接口。ASGI 规范 填补了这一空白,这意味着我们现在能够开始构建一组可在所有异步框架中使用的通用工具。

Uvicorn currently supports HTTP/1.1 and WebSockets.
Uvicorn 目前支持 HTTP/1.1 和 WebSockets。

Uvicorn 只有少量的核心依賴,這使它比其他Web 伺服器(如uWSGI)更輕量。 Uvicorn 也能輕鬆與Docker、Kubernetes 等容器技術整合,這對於需要快速部署的開發團隊來說,是一個很大的優勢。

Uvicorn 是由 Starlette 框架的作者编写的 ASGI 服务器,旨在提供高性能的异步请求处理能力。它使用 asyncio 库实现异步 I/O 操作,支持 HTTP 和 WebSocket 协议,可与各种 ASGI 应用程序框架(如 FastAPI、Django、Starlette 等)配合使用。

Uvicorn 和 uWSGI 对比区别

在这里插入图片描述

  • 如果您的应用是以异步方式构建(如使用 FastAPI),并且您需要快速开发和测试,可以选择 Uvicorn。
  • 如果您在生产环境中使用传统的 WSGI 应用程序,并且希望利用多进程管理和其他高级特性,可以选择 uWSGI,尤其是在需要与 Nginx 等 Web 服务器集成时。

安装 Uvicorn

pip install uvicorn

使用示例

下面是一个简单的示例,演示了如何使用 Uvicorn 启动一个异步 Web 服务:

# main.py

from fastapi import FastAPI

app = FastAPI()

@app.get("/")
async def read_root():
    return {
    
    "message": "Hello, World!"}

保存以上代码到 main.py 文件中。然后,在命令行中执行以下命令:

uvicorn main:app --reload

这将启动一个名为 main 的 ASGI 应用程序,使用 Uvicorn 服务器运行在本地主机的默认端口 8000 上,并监听根路径 / 的 GET 请求。在浏览器中访问 http://localhost:8000,将看到 “Hello, World!” 的消息。

猜你喜欢

转载自blog.csdn.net/inthat/article/details/146666313
今日推荐