返回介绍

WSGI服务器

发布于 2019-11-13 06:14:51 字数 7612 浏览 964 评论 0 收藏 0

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

Django 的startproject 管理命名为你设置一个简单的默认WSGI 配置,你可以根据你项目的需要做调整并指定任何与WSGI 兼容的应用服务器使用。

Django 包含以下WSGI 服务器的入门文档:

application 对象

使用WSGI 部署的核心概览是application 可调用对象,应用服务器使用它来与你的代码进行交换。在Python 模块中,它通常一个名为application 的对象提供给服务器使用。

startproject 命令创建一个<project_name>/wsgi.py 文件,它就包含这样一个application 可调用对象。

它既可用于Django 的开发服务器,也可以用于线上WSGI 的部署。

WSGI 服务器从它们的配置中获得application 可调用对象的路径。Django 内建的服务器,叫做runserverrunfcgi 命令,是从WSGI_APPLICATION 设置中读取它。默认情况下,它设置为<project_name>.wsgi.application,指向<project_name>/wsgi.py 中的application 可调用对象。

配置settings 模块

当WSGI 服务器加载你的应用时,Django 需要导入settings 模块 —— 这里是你的全部应用定义的地方。

Django 使用DJANGO_SETTINGS_MODULE 环境变量来定位settings 模块。它包含settings 模块的路径,以点分法表示。对于开发环境和线上环境,你可以使用不同的值;这完全取决于你如何组织你的settings。

如果这个变量没有设置,默认的wsgi.py 设置为mysite.settings,其中mysite 为你的项目的名称。这是runserver 如何找到默认的settings 文件的机制。

因为环境变量是进程范围的,当你在同一个进程中运行多个Django 站点时,它将不能工作。使用mod_wsgi 就是这个情况。

为了避免这个问题,可以使用mod_wsgi 的守护进程模式,让每个站点位于它自己的守护进程中,或者在wsgi.py中通过强制使用os.environ["DJANGO_SETTINGS_MODULE"] = "mysite.settings" 来覆盖这个值。

运用WSGI 中间件

你可以简单地封装application 对象来运用 WSGI 中间件。 例如,你可以在wsgi.py 的底下添加以下这些行:

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

如果你结合使用 Django 的application 与另外一个WSGI application 框架,你还可以替换Django WSGI 的application 为一个自定义的WSGI application。

某些第三方的WSGI 中间件在处理完一个请求后不调用响应对象上的close —— most notably Sentry’s error reporting middleware up to version 2.0.7。这些情况下,不会发送request_finished 信号。这可能导致数据库和memcache 服务的空闲连接。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文