views:

547

answers:

4

I'm running a Django app on Apache + mod_python. When I make some changes to the code, sometimes they have effect immediately, other times they don't, until I restart Apache. However I don't really want to do that since it's a production server running other stuff too. Is there some other way to force that?

Just to make it clear, since I see some people get it wrong, I'm talking about a production environment. For development I'm using Django's development server, of course.

A: 

Use a test server included in Django. (like ./manage.py runserver 0.0.0.0:8080) It will do most things you would need during development. The only drawback is that it cannot handle simultaneous requests with multi-threading.

I've heard that there is a trick that setting Apache's max instances to 1 so that every code change is reflected immediately--but because you said you're running other services, so this may not be your case.

Achimnol
Thats "MaxRequestsPerChild 1" set in httpd.conf as told by zdmytriv, but DO NOT do this for site handling any load.
uswaretech
+10  A: 

If possible, you should switch to mod_wsgi. This is now the recommended way to serve Django anyway, and is much more efficient in terms of memory and server resources.

In mod_wsgi, each site has a .wsgi file associated with it. To restart a site, just touch the relevant file, and only that code will be reloaded.

Daniel Roseman
I'm a bit scared of this XXgi things after all the trouble I had with FastCGI (sure, it was Lighttpd, but still): http://stackoverflow.com/questions/393637/django-fastcgi-randomly-raising-operationalerror. Didn't know wsgi is the recommended way to deploy Django now. It used to be mod_python, right? Anyway, I'll look into it. Thanks!
ionut bizau
s/this things/these things/ :)
ionut bizau
As noted elsewhere, you must use mod_wsgi daemon mode to get feature whereby a reload will occur when WSGI script file is touched.
Graham Dumpleton
@ibz: mod_wsgi is so different from fastcgi that they are not comparable in any way.
S.Lott
Note that (as Graham Dumpleton mentions below) the touch-.wsgi-file-to-restart only works in daemon mode, not embedded mode.
Carl Meyer
A: 

You can reduce number of connections to 1 by setting "MaxRequestsPerChild 1" in your httpd.conf file. But do it only on test server, not production.

or

If you don't want to kill existing connections and still restart apache you can restart it "gracefully" by performing "apache2ctl gracefully" - all existing connections will be allowed to complete.

zdmytriv
"apache2ctl gracefully" sounds like a neat thing. Will definitely look into that, even though it's not exactly what I was looking for. Thanks for the tip!
ionut bizau
+4  A: 

As others have suggested, use mod_wsgi instead. To get the ability for automatic reloading, through touching the WSGI script file, or through a monitor that looks for code changes, you must be using daemon mode on UNIX. A slight of hand can be used to achieve same on Windows when using embedded mode. All the details can be found in:

http://code.google.com/p/modwsgi/wiki/ReloadingSourceCode

Graham Dumpleton