Yesterday, I cooked up a deploy.rb so that Capistrano can deploy a Django application. While there is a Python app called http://docs.fabfile.org/0.9.0/ from what I could tell, it was very general to running commands on multiple servers, and not really specific to checking out a web framework and deploying it to one or more servers.
First, my deploy.rb, and then my notes about how I used it. I have changed only one or two things from my real code. My application is called “clientportal” and the host running it is called “clientportal.isp.example.net”. On the server, it runs as a user called “clientportal”.
This code does not yet invoke the Django database migrations, which it ought to, and I’ll do another blog post once I figure out that part.
Some details. First, I put my settings.py file into my /home/clientportal directory. I do not check this file into my repo, because it always specific to the installation (it’s different on your laptop than on the devel server or the production server). Also see my:
Like http://blog.perplexedlabs.com/2010/02/08/deployment-using-capistrano-and-webistrano-via-rails-and-phusion-passenger/ I had to adjust my django.wsgi file as well. I wound up with:
The important changes were to the path that was added. It used to add $HOME/clientportal and $HOME to the path, but now it is one directory deeper, and you will notice above in the update_database_yml task that it creates a symlink in $HOME/clientportal with the name “clientportal” that is essentially the same as “current”.
This is necessary because the settings are loaded as “clientportal.settings”, and python basically turns the . into a / when looking for the file. I could have just changed the name of the settings file, but we had other modules that were loaded using the clientportal. namespace.
Note that the server already had it’s apache configured to do what was needed. I would normally package these config files up into a .deb file, but I haven’t done that yet for this project, it being my first django project.
I am not sure if I actually have to restart apache. I added that for good luck, and and I added:
My apache config looks like:
Some other links I found, but I didn’t use much: http://groups.google.com/group/django-developers/browse_thread/thread/f34e59275e04f9c5?pli=1 http://gnuvince.wordpress.com/2008/01/10/deploying-django/