Web Server Gateway Interface
Das Web Server Gateway Interface (WSGI) ist eine Schnittstellen-Spezifikation für die Programmiersprache Python, die eine Schnittstelle zwischen Webservern und Webframeworks bzw. Web Application Servern festlegt, um die Portabilität von Webanwendungen auf unterschiedlichen Webservern zu fördern.
Details
Die eigentliche Schnittstelle besteht auf Anwendungsseite aus einem aufrufbaren Objekt. Dieses erhält als Parameter die Umgebungsvariablen und ein Funktionsobjekt (start_response
im Beispiel) und muss ein iterierbares Objekt zurückgeben. Die Umgebungsvariablen werden als assoziatives Array übergeben (environ
im Beispiel). Das Funktionsobjekt dient dazu, die HTTP-Header auszugeben; es wird von der Server-Seite aufgerufen, bevor der Rückgabewert der Funktion an den Client gesendet wird.
Beispiel:
def app(environ, start_response):
start_response('200 OK', [('content-type', 'text/plain')])
return [b'Hello world!']
Hintergrund
In den letzten Jahren entwickelte sich auf der Basis von Python eine Vielzahl von Web Application Frameworks und Web Application Servern. Die Schwierigkeit bestand darin, dass die Auswahl eines Frameworks die Auswahl des Webservers einschränkte und umgekehrt. Dies machte es schwer, sich für ein System zu entscheiden und erschwerte zusätzlich die Portabilität, wenn man später ein anderes Framework bzw. einen anderen Webserver verwenden wollte. Um diesem Problem entgegenzuwirken wurde das Python Web Server Gateway Interface geschaffen – gedacht als einheitliche Schnittstelle (Middleware) zwischen den beiden Welten. Dies sollte eine Trennung des Webservers und der dahinterliegenden Anwendung ermöglichen und damit die Portabilität für diese erhöhen. Der erste Entwurf des zugehörigen Python Enhancement Proposal 333 war vom 7. Dezember 2003.
Anwendung
Bisher sind nur wenige Websites für eine extensive Nutzung von WSGI bekannt geworden.[1][2] Verwendung findet derzeit WSGI vor allem über mod_wsgi in Apache Web Servern oder über uwsgi in Nginx-[3] oder Cherokee[4]-Servern. Beide Varianten können als eigenständiger Systemdienst (daemon) vom Webserver getrennt arbeiten und bieten so neben bedingten Sicherheits- und Performance-Vorteilen auch komfortable Möglichkeiten zur Skalierung und unterbrechungsfreien Updates.[5][6]
Weblinks
- PEP 333 -- Python Web Server Gateway Interface v1.0
- PEP 3333 -- Python Web Server Gateway Interface v1.0.1, leichte Veränderungen um den PEP von Python 3 zu genügen
- WSGI Informationsseite
Einzelnachweise
- mod_wsgi Usage Statistics. Abgerufen am 1. August 2020.
- w3techs.com
- wiki.nginx.org
- cherokee-project.com
- uwsgi Zerg Mode. Abgerufen am 27. September 2013.
- mod_wsgi Daemon Delegation. Abgerufen am 27. September 2013.