作为 Python Web 开发者来说,在开发程序阶段一般是不会接触到 WSGI 这个名词的,但当程序开发完成,考虑上线部署的时候,WSGI 规范是一个绕不开的话题,本文将介绍何为 WSGI。
WSGI 全拼 Web Server Gateway Interface,是为 Python 语言定义的 Web 服务器和 Web 应用程序(或框架)之间的一种通用编程接口。翻译成白话就是说 WSGI 是一个协议,就像 HTTP 协议定义了客户端和服务端数据传输的规范,WSGI 协议定义了 Web 服务器和 Web 应用程序之间协同工作的规范。
Python Web 应用部署方案
Flask
或 Django
等 Web 框架都提供了内置的 Web Server,本地开发阶段可以使用 flask run
或 python manage.py runserver
来分别启动 Flask
或 Django
内置的 Server。
在生产环境部署应用时,通常不会使用框架内置的 Server,而是使用 Gunicorn
或 uWSGI
来部署,以获得更好的性能。部署过 Python Web 应用的同学应该对如下部署架构有所了解,左侧是浏览器,右侧是服务器。在服务器内部,首先通过 Nginx
来监听 80/443
端口,当接收到来自客户端的请求时,Nginx
会将请求转发到监听 5000
端口的 Gunicorn/uWSGI
Server,接着请求会通过 WSGI 协议被传递到 Flask/Django
框架,在框架内部处理请求逻辑后,会将响应信息按照原路返回。
你可能会问,Nginx
性能很高,为什么不将应用直接部署到 Nginx
上,而是中间通过 Gunicorn/uWSGI
做一层转发呢?因为 Nginx
没有遵循 WSGI 规范,并不能像 Gunicorn/uWSGI
这样很容易的与 Flask/Django
框架结合起来。
WSGI 规范
根据 Python Web 应用部署架构,我们知道了 WSGI 所处的位置,接下来看下 WSGI 规范具体定义了哪些内容。
如同 HTTP 协议有一个客户端和一个服务端,WSGI 协议有一个 Applica