WSGI

Эта статья находится на начальном уровне проработки, в одной из её версий выборочно используется текст из источника, распространяемого под свободной лицензией
Материал из энциклопедии Руниверсалис

WSGI (англ. Web Server Gateway Interface) — стандарт взаимодействия между Python-программой, выполняющейся на стороне сервера, и самим веб-сервером[1], например Apache.

Идея

В Python существует большое количество различного рода веб-фреймворков (каркасов), тулкитов и библиотек. Для каждого из них — собственный метод установки и настройки, они не умеют взаимодействовать между собой. Это может стать затруднением для тех, кто только начинает изучать Python, так как, например, выбор определённого фреймворка может ограничить выбор веб-сервера, и наоборот.

WSGI предоставляет простой и универсальный интерфейс между большинством веб-серверов и веб-приложениями или фреймворками.

Спецификации

По стандарту, WSGI-приложение должно удовлетворять следующим требованиям:

  • должно быть вызываемым (callable) объектом (обычно это функция или метод)
  • принимать два параметра:
    • словарь переменных окружения (environ)[2]
    • обработчик запроса (start_response)[3]
  • вызывать обработчик запроса с кодом HTTP-ответа и HTTP-заголовками
  • возвращать итерируемый объект с телом ответа

Простейшим примером WSGI-приложения может служить такая функция-генератор:

 def application(environ, start_response):
    start_response('200 OK', [('Content-Type', 'text/plain')])
    yield b'Hello, World!\n'

Middleware

Помимо приложений и серверов, стандарт дает определение middleware-компонентов, предоставляющих интерфейсы как приложению, так и серверу. То есть для сервера middleware является приложением, а для приложения — сервером. Это позволяет составлять «цепочки» WSGI-совместимых middleware. Middleware — простая обертка над объектом приложения, реализовать её можно через замыкание.[4]

Middleware могут брать на себя следующие функции (но не ограничиваются этим):

Совместимы с WSGI

Конечные приложения

Веб-фреймворки и серверы приложений

Библиотеки

  • Python Paste — библиотека компонентов для работы с WSGI-приложениями

Аналоги

  • Rack — аналогичный подход, реализованный для Ruby[6];
  • JSGI[en] — для JavaScript[7];
  • PSGI — для Perl.
  • ASGI – духовный наследник WSGI, добавляющий поддержку асинхронных приложений.

См. также

Примечания

  1. "WSGI, Введение", Юревич Юрий. Дата обращения: 15 октября 2016. Архивировано 19 октября 2016 года.
  2. environ variables. Дата обращения: 15 октября 2016. Архивировано 7 июня 2020 года.
  3. start_response. Дата обращения: 15 октября 2016. Архивировано 7 июня 2020 года.
  4. Creating WSGI middleware. Дата обращения: 15 октября 2016. Архивировано 4 мая 2017 года.
  5. Technical Architecture, Developer Book (OpenERP). Дата обращения: 10 октября 2012. Архивировано 18 октября 2012 года.
  6. Yehuda Katz, Rack as a Transformative Figure, 2009. Дата обращения: 31 октября 2012. Архивировано 27 февраля 2012 года.
  7. JSGI & Jack Архивировано 17 декабря 2014 года.

Ссылки

  • PEP 3333 — Python Enhancement Proposal, определяющий стандарт интерфейса
  • wsgi.org — крупнейшая вики об WSGI

Литература

  • James Gardner. The Definitive Guide to Pylons. — Apress, 2008. — 568 с. — P. 369-388. — ISBN 9781590599341.