Managing Django Projects on Your Server with Style

This article is outdated, you’ll find an updated article here.

A friend is in the process of setting up a new slice at everbody’s favorite VPS provider Slicehost and asked for some advice. I use MySQL, Nginx & Apache/mod_wsgi on Ubuntu to serve Django. I think Slicehost’s Articles are awesome and a great place to get help you get everything installed and running, so for this article, I’ll focus on some personal preferences regarding directory structure and repo management.

One of the biggest difficulties I’ve had to tackle lately is the rapid progress of Django. I have a number of client sites hosted on my slice and have had to freeze them at certain times when backwards incompatible changes come along. My original approach made this really messy, because I only accounted for having one copy of any given third party repo, symlinked from /usr/local/src to my Python site-packages directory. My new approach takes advantage of being able to set your PYTHONPATH at runtime.

My directory structure looks like this:

|-django
|--projects
|---domain1.com
|---domain2.com
|---domain3.com

Each site has the following structure:

|-domain1.com
|--apache
|---django.wsgi
|--django
|--domain1_project
|---__init__.py
|---app1
|---app2
|---manage.py
|---settings.py
|---static
|---templates
|---urls.py
|--third_party_repo1
|--third_party_repo2

Just drop domain1.com in your PYTHONPATH and you’re good to go. I usually start with django and the third party repos as symlinks to a current checkout of the code in /usr/local/src. When the project is completed or if the linked code passes us by, I simply replace the symlink with an actual copy of the repo. This gives me a nice compartmentalized folder of the project that would be easy to move if needed. I can also update my repos in /usr/local/src without worrying about which project might break from the new code.

Have a better way to do things? Leave a comment and let me know. Thanks for reading and tune in next week to really geek out with Nginx & Apache/mod_wsgi configuration files.

Reader Comments

  • August 28, 2008 at 10:27 a.m. #
    apollo13 added:

    That’s typically the point where you want to use virtualenv :)
    http://pypi.python.org/pypi/virtualenv
    And for mod_wsgi integration: http://code.google.com/p/modwsgi/wiki/VirtualEnvironments

    One feature of virtualenv I always like to exploit: easy_install in a virtualenv looks into your PYTHONPATH to find already installed packages in it and just links to them (so no duplication). Using the multiversion flag for easy_install you could even choose between different version and share them between projects.

  • August 28, 2008 at 2:44 p.m. #
    njharman chimed in with:

    I wouldn’t mix python modules and non modules on the Python path. And I wouldn’t put my apps into a project module

    /web/domain1.com /manage.py /static /templates /python/django /python/project1 /python/project1/settings.py /python/project1/urls.py /python/app1 /python/app2 /python/third_party_repo1 /python/third_party_repo2

    Put /web/domain1.com/python/ on the Python path and modify manage.py to import project1.settings instead of just settings.

  • August 28, 2008 at 3:10 p.m. #
    Brian Luft added:

    I’m also a fan of virtualenv and I use Doug Hellman’s [http://www.doughellmann.com/projects/virtualenvwrapper/ virtualenvwrapper]. I’m still experimenting with finding the killer combo (for my tastes) for managing and versioning django apps and projects. I can envision a lot more discussion about distribution and deployment in the near future as projects like Pinax gain maturity and devs/admins are finding themselves dealing with large numbers of dependencies. I don’t know about you but I get pretty damned frustrated when I spend time tracking down a weird “bug” to discover it was the result of an out-of-date package somewhere higher on the path list.

    I’m also excited about [http://www.blueskyonmars.com/projects/paver/index.html Paver] since it integrates so tightly with the existing tools (distutils and setuptools) plus has support for virtualenv. It looks like it will make the creation of virtualenv bootstrap scripts a little more painless.

Got something to say?





This was written on August, 28 2008 and is filed in django.

Our Products

Premier Real Estate Websites
Our simple and easy real estate CMS. Now open for full developer access.
Trailmapping
Still in development, Trailmapping is a GPS enabled trail guide and trip logger.

Categories

Archives

Elsewhere

What I’ve been up to online

  • wow, iwantsandyand now pownce both turning out the lights with 2 weeks notice
    15 hours, 50 minutes ago #
  • Hire managers of one - (37signals)
    Self-starters are better than people that need their hand held.
    4 days, 21 hours ago #
  • s3Slider jQuery plugin - Overview
    slick Flash-like slideshow with text overlays in jQuery
    5 days, 15 hours ago #
  • Hypothetically speaking, if a startup you worked for lost funding, owed you money and wouldn't respond to your messages, what would you do?
    1 week, 3 days ago #
  • Ugh, Apple is really embracing DRM http://tinyurl.com/5adkbg
    1 week, 3 days ago #
  • @ericholscher nice post: http://tinyurl.com/699vjh
    1 week, 3 days ago #
  • rebuilding the Lincoln Loop company intranet
    1 week, 3 days ago #
  • sign of the economy: I've spent 2 hours today trying to collect money for delinquent accounts. Probably more than I spent in the last year.
    1 week, 4 days ago #
  • A List Apart: Articles: A More Useful 404

    1 week, 5 days ago #
  • I'm strongly considering ditching Backpack in favor of Google Apps
    1 week, 6 days ago #
  • Scratching my own itch: "Drive-by" comments for git repos. No diffs, no patches, just click & comment. http://tinyurl.com/5kmos8
    2 weeks ago #
  • Rancho - Home
    Django Basecamp clone
    2 weeks ago #
  • our top-secret code commenting project
     
    2 weeks ago #
  • Cola: Real-Time Shared Editing on Vimeo

    2 weeks, 2 days ago #
  • If you need to pass HTTP Authorization headers through mod_wsgi, make sure you've turned WSGIPassAuthorization On http://tinyurl.com/6q2w98
    2 weeks, 3 days ago #

Interested in working with us?
Fill out the form below or contact us at:

PO Box 774441
Steamboat Springs, CO
80477

ph: 970.879.8810
fx:  970.367.8596
info@lincolnloop.com