What is the Python equivalent of Tomcat?
This question likely betrays a misconception, but I'm curious what the "Tomcat" of the Python world is.
All of my web programming experience is in Java (or Groovy) so I think in Java terms. And when I think of making a basic web-app, I think of writing some servlets, building a WAR file, and deploying it in Tomcat or another servlet container.
In Python, suppose I wrote some code that was capable of responding to HTTP requests, what would I do with it? How would I deploy it?
Specifically: What is the most commonly used container in Python? And is there an equivalent of a WAR file, a standard packaging of a web-app into one file that works in the various containers?
There are different approaches which have one thing in common: They usually communicate via WSGI with their "container" (the server receiving the HTTP requests before they go to your Python code).
There are various containers:
- wsgiref - a very simple reference implementation which is nice during development
- Apache with mod_wsgi
- most other Webservers with a module adding WSGI support
- many more
when I think of making a basic web-app, I think of writing some servlets, building a WAR file, and deploying it in Tomcat or another servlet container.
That's nice, but irrelevant. That's just a Java-ism, and doesn't apply very widely outside Java.
In Python, suppose I wrote some code that was capable of responding to HTTP requests, what would I do with it? How would I deploy it?
That depends.
What is the most commonly used container in Python?
There isn't one.
And is there an equivalent of a WAR file, a standard packaging of a web-app into one file that works in the various containers?
There isn't one.
HTTP is a protocol for producing a response to a request. That's it. It's really a very small thing.
You have CGI scripts which can respond to a request. The Python cgi
library can do that. http://docs.python.org/library/cgi.html.
This is relatively inefficient because the simple CGI rule is "fire off a new process for each request." It can also be insecure if the script allows elevated privileges or badly planned-out uploads.
You have the mod_wsgi
framework to connect Apache to Python. This can behave like CGI, or it can have a dedicated Python "daemon" running at the end of a named pipe.
The WSGI standard defines a format for request and response processing that's very handy and very extensible. Most of the frameworks -- in one way or another -- are WSGI compatible.
Finally, there are more complete frameworks that include class definitions for requests and responses, URL parsing, Authentication, Authorization, etc., etc.
Here's a list: http://wiki.python.org/moin/WebFrameworks