Hypercorn 是一个支持异步 ASGI 和同步 WSGI 应用的高效 Python 服务器。它结合了现代协议支持(包括 HTTP/1、HTTP/2 和 HTTP/3),并且为异步 Web 框架(如 FastAPI 和 Quart)提供了卓越的性能和灵活性。通过 Hypercorn,开发者可以轻松处理高并发请求,同时支持多种协议和事件循环。
⭕️宇宙起点
💯 核心功能
1. 多协议支持
Hypercorn 支持 HTTP/1、HTTP/2 和 HTTP/3 协议,同时也支持 WebSockets。HTTP/2 和 HTTP/3 的引入极大提高了并发性能和传输效率,尤其在需要处理大量并发请求的应用中表现优异。
2. 多事件循环支持
Hypercorn 不仅支持 Python 的 asyncio
事件循环,还支持 trio
,并且与 uvloop
完全兼容。这种灵活性允许开发者根据应用的需求选择最合适的事件循环,以实现更高效的并发性能。
3. 灵活的配置方式
Hypercorn 提供了多种配置方式,包括:
- 命令行参数:可以快速设置服务器启动参数。
- TOML 文件:适合项目中统一管理配置。
- Python 配置模块:可以通过动态代码生成配置文件。
例如,可以使用.toml
文件进行配置:
hypercorn --config config.toml
TOML 文件示例:
bind = "127.0.0.1:8000"
access_log_format = "%(h)s %(r)s %(s)s"
Python 动态配置示例:
from hypercorn.config import Config
config = Config()
config.bind = ["127.0.0.1:8000"]
4. 优雅的关闭机制
Hypercorn 支持优雅关闭功能,当收到退出信号(如 SIGTERM
)时,服务器会等待正在处理的请求完成后才退出,避免请求丢失。以下是实现优雅关闭的代码示例:
import asyncio
import signal
async def app(scope, receive, send):
if scope['type'] == 'http':
await send