Uvicorn

  • 基于 uvloop 和 httptools 构建的非常快速的 ASGI 服务器
  • 它不是一个 Web 框架,而是一个服务器
  • 例如,它不是一个提供路径路由的框架,这是 FastAPI 框架提供的东西
  • 它是 Starlette 和 FastAPI 的推荐使用的服务器

总结

uvicorn 是运行 FastAPI 应用程序的主要 Web 服务器,uvicorn 和 Gunicorn 结合使用,拥有一个异步多进程服务器

什么是 ASGI、WSGI

WSGI

wiki 上的解释

  • Web Server Gateway Interface
  • Web 服务器网关接口
  • 是为 Python 定义的 Web 服务器和 Web 应用程序或框架之间的一种简单而通用的接口

WSGI 的问题

  • 随着移动网络的发展,Web 技术也在升级,比如 WebSocket、HTTP/2,HTTP/3
  • WSGI 应用是一个单调用、同步接口,即输入一个请求,返回一个响应;这个模式无法支持长连接或者 WebSocket 这样的连接
  • 即使想办法将 WSGI 应用改成异步,还有另一个限制:一个 URL 对应一个请求,而 HTTP/2、Websocket 等在一个 URL 里会出现多个请求

ASGI 的背景

  • 在 Python 3.5+ 增加 async/await 特性之后,异步编程变得异常火爆
  • 但 Python 仍缺乏用于 asyncio 框架最低限度的低级服务器/应用程序接口
  • 而 ASGI 协议规范的出现填补了这一空白,这意味着现在能够开始构建可在所有异步框架中使用的通用工具集

ASGI

  • Asynchronous Server Gateway Interface
  • 异步服务器网关接口
  • ASGI 是 WSGI 的继承者,旨在提供支持异步的 Python web 服务器、框架和应用程序之间的标准接口
  • ASGI 为异步和同步应用程序提供了一个标准,继续成为 web 服务器、框架和应用程序(如异步 python 中的 WSGI)之间的标准兼容性

简单总结

  • WSGI 是为同步应用程序提供标准,不支持 WebSocket
  • ASGI 是为异步、同步应用程序提供标准,支持 WSGI 不支持当前 web 开发中的一些新的协议标准
  • ASGI 是对 WSGI 的扩展

最简单的 FastAPI 代码

  1. from fastapi import FastAPI
  2. app = FastAPI()
  3. @app.get("/")
  4. async def root():
  5. return {"message": "Hello World"}

命令行启动 uvicorn

进到 py 文件所处目录下的命令行运行
uvicorn test1:app —reload
image.png

使用 uvicorn.run()启动uvicorn

  1. from fastapi import FastAPI
  2. app = FastAPI()
  3. @app.get("/")
  4. async def root():
  5. return {"message": "Hello World"}
  6. if __name__ == '__main__':
  7. uvicorn.run(app="test1:app", host="127.0.0.1", port=8000, reload=True, debug=True)
  • 这样就不用敲命令行啦
  • uvicorn 有什么命令行参数,run() 方法就有什么参数

    uvicorn 常用参数

    | 参数 | 作用 | | —- | —- | | app | 运行的 py 文件:FastAPI 实例对象 | | host | 访问url,默认 127.0.0.1 | | port | 访问端口,默认 8080 | | reload | 热更新,有内容修改自动重启服务器 | | debug | 同 reload | | reload_dirs | 设置需要 reload 的目录,List[str] 类型 | | log_level | 设置日志级别,默认 info |