Zum Inhalt springen

mod_python

aus Wikipedia, der freien Enzyklopädie
Dies ist eine alte Version dieser Seite, zuletzt bearbeitet am 7. April 2008 um 17:00 Uhr durch Valshaq (Diskussion | Beiträge) (mod_python ist veraltet. Diskussion z.B. http://www.python-forum.de/topic-14059.html?highlight=modpython). Sie kann sich erheblich von der aktuellen Version unterscheiden.

mod_python ist ein Modul für den Apache-HTTP-Server, das die Programmiersprache Python in den Webserver einbindet. Ziel war die Ablösung des „Common Gateway Interface“ (CGI) zur Ausführung von Python-Skripten. Heutzutage sollte man es nicht mehr verwenden, da moderne und leistungsfähige Frameworks wie Pylons, Django oder Werkzeug zur Verfügung stehen, die auf WSGI bzw. FastCGI aufsetzen und nicht die Nachteile von mod_python mit sich bringen.

Vorteile

Bei gewöhnlichen CGI-Programmen wird für jede Anfrage ein neuer Prozess auf dem Server gestartet. Dieses Verfahren funktioniert gut auf Seiten mit mäßigem Besucherandrang; auf Seiten mit hohem Besucherandrang skaliert dieses Verfahren zu schlecht. Es gibt zwar Methoden, um CGI zu beschleunigen, wie „FastCGI“, aber oft ist es einfacher, ein spezielles Modul zur Einbettung einer Sprache in den Webserver zu verwenden. Genau dafür wurde „mod_python“ entwickelt. Da der Prozess nach der Bearbeitung einer Anfrage nicht beendet wird, können persistente Daten, wie z. B. Datenbankverbindungen, gespeichert werden, und die Verzögerung durch das Starten eines neuen Prozesses entfällt. Auf diese Weise kann Overhead bei der Ausführung vermieden werden.

Da „mod_python“-Module direkt in den Webserver integriert sind, können sie praktisch alles erledigen, was sonst in C programmierte Apache-Module erledigen: Implementierung von anderen Protokollen als HTTP, Filterung der Anfrage und der Antwort, Ermittlung des Datenformats usw.

Nachteile

Da die Skripte direkt im Server laufen, werden sie mit den Rechten des Serverprozesses ausgeführt. Normalerweise ist das kein Problem, aber bei unvorsichtigem Umgang können Module wie „mod_python“ zu Sicherheitslücken führen. Dieses Problem betrifft alle Programmiersprachen, die direkt in den Webserver eingebettet werden und ist nicht Python-spezifisch. Skripte unter mod_python verhalten sich oft nicht so, wie erwartet. Die Lowlevel-Programmierung mittels CGI oder mod_python ist veraltet und fehleranfällig. Statt immer wieder das Rad neu zu erfinden, sollte auf eines der Frameworks wie z.B. Pylons, Django oder Werkzeug zurückgegriffen werden. Dies gilt insbesondere, um der Vermischung von Präsentations- und Programmlogik vorzubeugen.

Geschichte

Die erste Version von „mod_python“ wurde im Jahr 2000 von Gregory Trubetskoy freigegeben. Seit 2002 ist „mod_python“ ein offizielles Projekt der Apache Software Foundation.