Web Server Gateway Interface
O Web Server Gateway Interface (WSGI), em português Interface de Porta de Entrada do Servidor Web, é uma especificação para uma interface simples e universal entre servidores web e aplicações web ou frameworks para a linguagem de programação Python. Foi originalmente especificada na PEP 333, de autoria de Philip J. Eby, e publicada em 7 de dezembro de 2003.[1] Desde então foi adotada como um padrão para o desenvolvimento de aplicações web em Python. A última versão da especificação é v1.0.1, também conhecida como PEP 3333, publicada em 26 de setembro de 2010.[2]
Ideia
editarFrameworks de aplicação web em Python têm sido um problema para novos usuários de Python pois a escolha do framework web pode limitar a escolha de servidores web úteis, e vice-versa.
Aplicações em Python eram frequentemente projetadas para apenas um dos servidores CGI, FastCGI, mod_python ou alguma outra API personalizada de um servidor web específico.
O WSGI foi criado como uma interface de baixo-nível entre servidores web e aplicações web ou frameworks para promover uma base comum para o desenvolvimento de aplicações web portáteis.
Visão geral da especificação
editarO WSGI possui dois lados: o lado "servidor" ou "gateway" e o lado "aplicação" ou "framework". Para processar uma requisição WSGI, o lado servidor fornece informações de ambiente e uma função de callback para o lado aplicação. A aplicação processa a requisição e retorna a resposta para o lado servidor usando a função de callback que o lado servidor forneceu.
O chamado middleware WSGI implementa os dois lados da API, desta forma ele pode intermediar entre um servidor WSGI e uma aplicação WSGI: o middleware age como uma aplicação de algum ponto de vista do servidor WSGI e como um servidor de algum ponto de vista da aplicação WSGI. Um componente "middleware" pode realizar funções como:
- Rotear uma requisição para diferentes objetos da aplicação baseados na URL alvo, após mudar as variáveis de ambiente adequadamente.
- Permitir várias aplicações ou frameworks executarem lado a lado no mesmo processo
- Balanceamento de carga e processamento remoto, enviando requisições e respostas sobre uma rede
- Realizar pós-processamento de conteúdo, como aplicar folhas de estilo XSLT
Aplicação de exemplo
editarUma aplicação "Olá Mundo" compatível com WSGI escrita em Python:
def aplicacao(ambiente, resposta_inicio):
resposta_inicio('200 OK', [('Content-Type', 'text/plain')])
yield 'Olá Mundo\n'
Onde:
- Linha 1 define um "chamável" denominado
aplicacao
, que leva dois parâmetros,ambiente
eresposta_inicio
.ambiente
é um dicionário contendo variáveis de ambiente em CGI.resposta_inicio
é um "chamável" que leva dois parâmetros necessáriosestado
ecabecalhos_resposta
. - Linha 2 chama
resposta_inicio
, especificando "200 OK" como o estado e o cabeçalho "Content-Type". - Linha 3 retorna o corpo de resposta como um literal string.
Aplicações e frameworks compatíveis com WSGI
editarHá vários frameworks de aplicação web que suportam WSGI:
Servidores que suportam WSGI
editarEsta é uma lista de servidores WSGI. Em alguns casos são apenas sistemas WSGI, em outros um pacote que inclui um servidor.
- ajp-wsgi
- Aspen[12]
- cherrypy.wsgiserver
- chiral.web.httpd
- cogen.web.wsgi
- FAPWS
- fcgiapp
- flup[13]
- gevent-fastcgi
- Gunicorn
- ISAPI-WSGI
- James
- Julep
- m2twisted
- modjy
- mod_wsgi
- NWSGI
- paste.httpserver
- phusion passenger
- python-fastcgi
- Spawning
- twisted.web
- uWSGI
- werkzeug.serving
- wsgid
- WSGIUtils
- wsgiref (Python 3)
Ligações externas
editarReferências
- ↑ «PEP 333, Python Web Server Gateway Interface v1.0»
- ↑ «PEP 3333, Python Web Server Gateway Interface v1.0.1»
- ↑ «Bobo light-weight framework for creating WSGI web applications»
- ↑ «Bottle Micro-Framework»
- ↑ «Django with WSGI support»
- ↑ «prestans Micro-Framework»
- ↑ «restlite server tools for quick prototyping»
- ↑ «Ulibweb github source code»
- ↑ «web.py official site»
- ↑ «weblayer package for writing WSGI application»
- ↑ «Werkzeug, the Python WSGI Utility Library»
- ↑ http://aspen.io/
- ↑ https://www.saddi.com/software/flup/