如何使用 WSGI 进行部署

Django 的主要部署平台是 WSGI,它是 Web 服务器和 Web 应用的 Python 标准。

Django 的管理命令 startproject 生成了一个简单的默认 WSGI 配置,你可以按照自己项目的需要去调整这个配置,任何兼容 WSGI 的应用服务器都可以直接使用。

Django 提供了下面这些 WSGI 服务的入门文档:

application 对象

用 WSGI 部署的关键是 application callable,应用服务器用它与你的代码交互。 application callable 一般以一个位于 Python 模块中,名为 application 的对象的形式提供,且对服务器可见。

startproject 命令创建了文件 <project_name>/wsgi.py,其中包含了 application callable。

Django 开发服务器和生产环境的 WSGI 部署都用到了它。

WSGI 服务器从其配置中获取 application callable 的路径。Django 的默认服务器( runserver 命令),从配置项 WSGI_APPLICATION 中获取。默认值是 <project_name>.wsgi.application,指向 <project_name>/wsgi.py 中的 application callable。

配置 settings 模块

当 WSGI 服务器加载应用时,Django 需要导入配置模块——完整定义应用的地方。

Django 利用 DJANGO_SETTINGS_MODULE 环境变量来定位合适的配置模块。它必须包含到配置模块的点式路径。开发环境和生产环境可以配置不同值;这都取决于你是如何组织配置的。

若未设置该变量, wsgi.py 默认将其设置为 mysite.settingsmysite 即工程名字。这就是 runserver 默认的发现默认配置行为。

注解

由于环境变量是进程级的,所以如果在同一进程运行多个 Django 站点将出错。这在使用 mod_wsgi 时会出现。

要避免此问题,为每个站点在后台进程使用 mod_wsgi 的后台模式,或者在 wsgi.py 中通过 os.environ["DJANGO_SETTINGS_MODULE"] = "mysite.settings" 重写来自环境变量的值。

应用 WSGI 中间件

要应用 WSGI 中间层,你只需简单包裹应用对象。举个例子,你可以在 wsgi.py 末尾添加以下代码:

from helloworld.wsgi import HelloWorldApplication
application = HelloWorldApplication(application)

如果你想将 Django 应用于一个 WSGI 应用或其它框架联合起来,可以用自定义 WSGI 应用替换 Django 的 WSGI 应用,前者会在稍晚时候将任务委托给 WSGI 应用。