当前位置: 首页 > news >正文

【Python】Uvicorn:Python 异步 ASGI 服务器详解

在这里插入图片描述

Uvicorn 是一个为 Python 设计的 ASGI(异步服务器网关接口)Web 服务器。它填补了 Python 在异步框架中缺乏一个最小化低层次服务器/应用接口的空白。Uvicorn 支持 HTTP/1.1 和 WebSockets,是构建现代异步Web应用的强大工具。

在这里插入图片描述
华丽的分割线

⭕️宇宙起点

    • 🎬 什么是 Uvicorn?
    • 🔨 Uvicorn 的主要功能和特性
    • 📦 Uvicorn 的常用启动参数
    • ♨️ 示例:使用 `uvicorn.run` 启动 ASGI 应用
    • ⚙️ 运行 Uvicorn 的高级配置
    • 🔧 使用 Gunicorn 部署 Uvicorn
    • 📥 下载地址
    • 💬 结语
      • 📒 参考文献


标题1

🎬 什么是 Uvicorn?

在这里插入图片描述

Uvicorn 是一个轻量级、高性能的 ASGI(Asynchronous Server Gateway Interface) 服务器,专为支持 Python 异步框架(如 FastAPI 和 Starlette)而设计。与传统的 WSGI 服务器(如 Gunicorn)不同,Uvicorn 旨在提供对异步 Web 框架的完全支持,并在性能和灵活性方面进行了大量优化。


标题2

🔨 Uvicorn 的主要功能和特性

  • 高性能:Uvicorn 使用 uvloop 作为默认的事件循环和 httptools 进行 HTTP 解析,因此比传统的 Python 服务器更快。
  • 支持多种协议:支持 HTTP 和 WebSocket 协议,并可配置 ASGI 2 或 ASGI 3 接口。
  • 配置灵活:支持通过命令行参数、环境变量或配置文件进行详细的服务器配置。

标题3

📦 Uvicorn 的常用启动参数

在使用 Uvicorn 启动 ASGI 应用时,通常通过命令行传递各种参数以控制其行为。下面列出了几个常用的启动参数及其用途:

参数作用示例
--host指定绑定的主机地址--host 127.0.0.1
--port指定端口号--port 8000
--workers指定工作进程数--workers 4
--reload启用自动重载,在开发时自动检测文件变动并重启服务器--reload
--log-level日志等级(infodebugerror--log-level debug
--ssl-keyfileSSL 密钥文件路径--ssl-keyfile ./path/to/key.pem
--ssl-certfileSSL 证书文件路径--ssl-certfile ./path/to/cert.pem
--backlog设置连接请求的最大等待队列数--backlog 2048
--limit-max-requests限制单个进程在重启前可处理的最大请求数--limit-max-requests 1000

这些参数可以灵活地组合使用,根据需要配置 Uvicorn 的运行行为。特别是对于生产环境,可以搭配 --workers 参数来启动多个进程,提高并发处理能力。


标题4

♨️ 示例:使用 uvicorn.run 启动 ASGI 应用

Uvicorn 既可以从命令行启动,也可以通过 Python 代码进行启动。以下是几种不同的启动方式:

1)使用 uvicorn.run() 启动

import uvicornasync def app(scope, receive, send):assert scope['type'] == 'http'await send({'type': 'http.response.start','status': 200,'headers': [[b'content-type', b'text/plain'],],})await send({'type': 'http.response.body','body': b'Hello, Uvicorn!',})if __name__ == "__main__":uvicorn.run("main:app", host="127.0.0.1", port=5000, log_level="info")

2)使用 ConfigServer 实例

当需要更细粒度的控制时,可以使用 ConfigServer 实例:

import uvicornasync def app(scope, receive, send):assert scope['type'] == 'http'await send({'type': 'http.response.start','status': 200,'headers': [[b'content-type', b'text/plain'],],})await send({'type': 'http.response.body','body': b'Hello, Uvicorn!',})if __name__ == "__main__":config = uvicorn.Config("main:app", host="127.0.0.1", port=5000, log_level="info")server = uvicorn.Server(config)server.run()

3)异步环境中启动 Uvicorn

如果要在已有的异步事件循环中启动,可以使用 uvicorn.Server.serve()

import asyncio
import uvicornasync def app(scope, receive, send):assert scope['type'] == 'http'await send({'type': 'http.response.start','status': 200,'headers': [[b'content-type', b'text/plain'],],})await send({'type': 'http.response.body','body': b'Hello, Uvicorn!',})async def main():config = uvicorn.Config("main:app", host="127.0.0.1", port=5000, log_level="info")server = uvicorn.Server(config)await server.serve()if __name__ == "__main__":asyncio.run(main())

标题5

⚙️ 运行 Uvicorn 的高级配置

Uvicorn 提供了多种高级配置选项来满足不同应用的需求,包括 HTTP 流量控制、SSL 设置、资源限制等。常用配置如下:

配置选项描述默认值
--limit-concurrency限制最大并发连接数,超出时返回 HTTP 503None
--timeout-keep-aliveKeep-Alive 超时时间,超过该时间未收到请求则断开连接5
--timeout-graceful-shutdown优雅关闭服务器的最大等待时间None
--ssl-versionSSL 协议版本(参考标准库 ssl 模块)17
--log-config日志配置文件路径None
--ws-ping-intervalWebSocket 心跳包发送间隔时间20.0
--ws-ping-timeoutWebSocket 心跳包超时时间20.0

这些参数可以在开发和生产环境中进行不同的调整,以提升服务器的响应速度和安全性。


标题6

🔧 使用 Gunicorn 部署 Uvicorn

在生产环境中,通常推荐使用 Gunicorn 搭配 Uvicorn 的工作进程模式来部署。这样可以充分利用多进程的优势,并且享有 Gunicorn 稳定的进程管理功能。

gunicorn -w 4 -k uvicorn.workers.UvicornWorker example:app

此命令会启动 4 个工作进程,并使用 UvicornWorker 管理 ASGI 应用的多进程环境。


标题7

📥 下载地址


Uvicorn 最新版 下载地址


标题8

💬 结语

Uvicorn 是一个功能强大、配置灵活且易于使用的异步 Web 服务器,非常适合现代 Python 异步框架的开发和部署。通过合理配置和结合 Gunicorn,可以充分利用其高性能和稳定性来处理各种 Web 请求。

📒 参考文献

  • Uvicorn 官网
  • Uvicorn GitHub仓库

TheEnd


在这里插入图片描述
在这里插入图片描述

http://www.lryc.cn/news/453420.html

相关文章:

  • 类型转换【C++提升】(隐式转换、显式转换、自定义转换、转换构造函数、转换运算符重载......你想知道的全都有)
  • 微信小程序hbuilderx+uniapp+Android 新农村综合风貌旅游展示平台
  • 【AI大模型】使用Embedding API
  • 面试速通宝典——11
  • python:reportlab 将多个图片合并成一个PDF文件
  • 决策树:机器学习中的强大工具
  • 平面电磁波(解麦克斯韦方程)电场相位是复数的积分常数,电场矢量每个分量都有一个相位。磁场相位和电场一样,这是因为无损介质中实数的波阻抗
  • 复习HTML(进阶)
  • Qt 每日面试题 -7
  • 《计算机原理与系统结构》学习系列——计算机的算数运算(下)
  • 二叉树进阶学习——从前序和中序遍历序列构造二叉树
  • 【数据分享】2000—2023年我国省市县三级逐年植被覆盖度(FVC)数据(Shp/Excel格式)
  • 【Python】Streamlit:为数据科学与机器学习打造的简易应用框架
  • OpenJudge | 置换选择排序
  • 如何提取b站的视频字幕,下载视频
  • Vue中使用ECharts实现热力图的详细教程
  • Arduino UNO R3自学笔记13 之 Arduino使用LM35如何测量温度?
  • 蓝桥杯【物联网】零基础到国奖之路:十六. 扩展模块之矩阵按键
  • Apollo9.0 Planning2.0决策规划算法代码详细解析 (4): PlanningComponent::Proc()
  • AAA Redis的过期删除策略+缓存雪崩+缓存一致性问题
  • 成都跃享未来教育咨询有限公司抖音小店:引领教育咨询新风尚
  • 【堆排】为何使用向下调整法建堆比向上调整法建堆更好呢?
  • 在Stable Diffusion WebUI中安装SadTalker插件时几种错误提示的处理方法
  • 使用ffmpeg合并视频和音频
  • 周末总结(2024/10/05)
  • 在Ubuntu中自动挂载SMB/CIFS共享
  • pWnOS2.0 靶机渗透( cms 渗透,php+mysql 网站渗透,密码碰撞)
  • 【AI】AIOT简介
  • picgo + typora + gitee图床
  • 【路径规划】多机器人路径规划