【Python系列】异步 Web 服务器

举报
kwan的解忧杂货铺 发表于 2024/11/27 23:55:14 2024/11/27
【摘要】 在现代 Web 开发中,异步编程已经成为提高性能和可伸缩性的关键技术。Uvicorn 是一个轻量级的 ASGI(Asynchronous Server Gateway Interface)服务器,用于托管 Python 异步 Web 应用程序。它基于 Starlette 和 FastAPI 框架,提供了一个快速、高效的方式来运行异步代码。 Uvicorn 的起源与特点Uvicorn 是由 T...

在现代 Web 开发中,异步编程已经成为提高性能和可伸缩性的关键技术。Uvicorn 是一个轻量级的 ASGI(Asynchronous Server Gateway Interface)服务器,用于托管 Python 异步 Web 应用程序。它基于 Starlette 和 FastAPI 框架,提供了一个快速、高效的方式来运行异步代码。

Uvicorn 的起源与特点

Uvicorn 是由 Tom Christie 创建的,他也是 Starlette 和 FastAPI 框架的作者。Uvicorn 的名字来源于“unicorn”(独角兽),象征着其在异步 Web 服务器领域的特殊地位。Uvicorn 的主要特点包括:

  1. 轻量级:Uvicorn 是一个轻量级的 ASGI 服务器,不需要额外的依赖,可以快速启动和运行。
  2. 高性能:由于其异步特性,Uvicorn 能够处理大量的并发连接,而不会阻塞线程。
  3. 兼容性:Uvicorn 兼容 ASGI 标准,可以与任何遵循 ASGI 的 Python 异步框架一起工作,如 Starlette、FastAPI 等。
  4. 跨平台:Uvicorn 可以在多种操作系统上运行,包括 Linux、macOS 和 Windows。
    在这里插入图片描述

Uvicorn 的安装与配置

要使用 Uvicorn,首先需要安装它。可以通过 pip 轻松安装:

pip install uvicorn

安装完成后,你需要一个 ASGI 应用程序。这里以 FastAPI 为例,因为它是 Uvicorn 的常用搭档。FastAPI 是一个现代、快速(高性能)的 Web 框架,用于构建 APIs,使用 Python 3.6+基于标准 Python 类型提示。

创建一个简单的 FastAPI 应用程序:

from fastapi import FastAPI

app = FastAPI()

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

启动 Uvicorn 服务器

一旦你有了 ASGI 应用程序,就可以使用 Uvicorn 来运行它。在 FastAPI 应用程序的同一目录下,打开终端并运行以下命令:

uvicorn main:app --reload

这里的main是包含 FastAPI 应用的 Python 文件的名称(不包括.py扩展名),app是 FastAPI 实例的名称。--reload参数用于在代码更改时自动重新加载服务器,这对于开发非常有用。

理解uvicorn.run函数

uvicorn.run函数是 Uvicorn 提供的另一种启动服务器的方式,它允许你以编程方式启动服务器。这在你想要在代码中控制服务器的启动和关闭时非常有用。函数的基本语法如下:

uvicorn.run(app, host, port)
  • app:你的 ASGI 应用程序实例。
  • host:服务器监听的主机地址。"0.0.0.0"表示监听所有可用的网络接口。
  • port:服务器监听的端口号。

示例:启动服务器

假设你有一个名为app的 FastAPI 应用程序实例,你可以使用以下代码启动服务器:

import uvicorn

uvicorn.run(app=app, host="0.0.0.0", port=8080)

这行代码告诉 Uvicorn 在所有网络接口的 8080 端口上启动app应用程序。这样,任何能够访问该服务器的客户端都可以通过http://<服务器IP>:8080来访问你的 Web 应用程序。

Uvicorn 的高级特性

Uvicorn 不仅仅是一个简单的服务器,它还提供了许多高级特性,如:

  1. 日志记录:Uvicorn 提供了详细的日志记录功能,可以帮助你监控应用程序的状态和性能。
  2. 生命周期控制:Uvicorn 允许你在应用程序启动和关闭时执行自定义代码。
  3. 中间件支持:Uvicorn 支持中间件,可以让你在请求处理流程中添加自定义逻辑。
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。