Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

"sites framework" on a single django instance

I want to serve up specialized RSS feeds on a different subdomain from the rest of the site.

Can I use the sites framework to use a different urls.py and settings.py file within a single django instance. or do I need to set up two apache locations and just set the different settings.py files in the apache conf.

The reason I need to set up two urls.py files is to avoid duplicate content. I don't want the main site to be available at rss.example.com and I don't want the specialized feeds to be accessible on example.com

Serving them from a single django instance would be ideal because we're on shared hosting with limited memory, and it seems like such a waste to have an instance open that only serves up rss.

edit: I concluded that multiple instances with seperate urls.py files would be easiest for me... but I found this article describing how to do it using a single instance:

http://effbot.org/zone/django-multihost.htm

Solution: Django tupperware

I ended up writing a framework for running multiple copies of a site on a single django instance.

The basic idea is to change out the SITE_ID setting on the fly for each request and load alternate settings from the database. It does this based on domain and uses SITE_ID = 1 by default (when it can't find anything)

All settings in the settings.py file act as defaults which are overridden by the settings stored in the database for the current site.

It works pretty well :) and it's running in production at http://rootbuzz.com

like image 967
Jiaaro Avatar asked Jun 17 '09 13:06

Jiaaro


2 Answers

With stock Django you must have a unique settings.py for each site... because the SITE_ID is defined in settings.py and is the key for which site is handling this request.

In other words, SITE_ID is global to your instance and therefore you need an instance for each site.

You can have a common urls.py if you wish because there's nothing preventing you from using the same ROOT_URLCONF in all your site settings.py files... or you can have diffent one for each site. In this case you would want to include sub URLs to prevent repeating yourself for any common URLs.

There are at least two methods you can try to serve from a single instance:

  1. Use apache + mod_wsgi and use the WSGIApplicationGroup and/or WSGIProcessGroup directives. I've never needed these before so can't be completely sure these will work the way you want, but regardless you can definitely use mod_wsgi in daemon mode to greatly improve your memory footprint.

  2. You can play with Django middleware to deny/allow URLs based on the request hostname (see HttpRequest.get_host() in the Django docs). For that matter, even though it would be a slight performance hit, you can put a decorator on all your views that checks the incoming host.

like image 186
Van Gale Avatar answered Sep 20 '22 12:09

Van Gale


FYI - I released django-dynamicsites which can be helpful with this issue - https://bitbucket.org/uysrc/django-dynamicsites/src

like image 28
Uysrc Avatar answered Sep 21 '22 12:09

Uysrc