ATTENZIONE: questa configurazione dopo i recenti aggiornamenti su dreamhost non è più consigliata, spesso causa crash nel sito che risulta irraggiungibile ritornando Errore 500, appena possibile pubblicherò una guida aggiornata…
Questa è una versione modificata rispetto alla guida ufficiale che potrete trovare sul wiki di dreamhost, difatti punta a farvi utilizzare non la versione preinstallata che trovate sul vostro server di python ma una vostra installazione personalizzata, con tutte le librerie di cui potreste aver bisogno, il documento originale in inglese da cui sono partito per scrivere questo tutorial si trova all’indirizzo:
http://forums.site5.com/showthread.php?t=10236
ora non mi rimane che augurarvi una buona lettura.
Per iniziare dopo aver completato le fasi di registrazione su dreamhost e una volta che avrete ottenuto un account ssh questi sono i passi da seguire per installare Django su Dreamhost, facendo uso però di una versione personalizzata di python:
- collegatevi in ssh sul vostro server
- una volta entrati nella vostra home digitate:
wget http://peak.telecommunity.com/dist/virtual-python.py python virtual-python.py
Questo creerà nella vostra home diverse cartelle (bin, lib, …) che vi consentiranno di avere una installazione personalizzata di python.
Il vantaggio di questo approccio è che vi consentirà di avere a vostra disposizione le librerie più indicate per il vostro progetto proprio come se aveste un vostro server personale. - Adesso è necessario scaricare ez_setup:
wget http://peak.telecommunity.com/dist/ez-setup.py ~/bin/python ez_setup.py
Adesso avete un’installazione completamente funzionante di python al vostro servizio, passiamo ora all’installazione delle librerire necessarie.
Librerie di python:
- La prima libreria necessaria per il funzionamento di Django su Dreamhost è quella per interfacciare Python al dbms MySQL, consiglio vivamente di scaricarsi ogni volta l’ultima versione della libreria che trova a questo indirizzo http://sourceforge.net/projects/mysql-python e al limite caricarla in ftp direttamente nella vostra home e seguire le indicazioni che vi sto per dare, per la sua installazione, ad eccezione della prima linea.
wget http://path.to.sourceforge.mirror/sourceforge/mysql-python/MySQL-python-1.2.1_p2.tar.gz tar zxvf MySQL-python-1.2.1_p2.tar.gz cd MySQL-python-1.2.1_p2 ~/bin/python setup.py install
- Installiamo una libreria che è utile (e necessaria) soprattutto se usate le immagini nel vostro progetto e gli ImageField, si tratta della libreria PIL (Python Imaging Library):
wget http://effbot.org/downloads/Imaging-1.1.5.tar.gz tar zxvf Imaging-1.1.5.tar.gz cd Imaging-1.1.5 ~/bin/python setup.py install
- Installiamo infine la libreria flup:
svn co http://svn.saddi.com/flup/trunk flup cd flup ~/bin/python setup.py install
a questo punto siete pronti per l’installazione vera e propria di Django.
Installazione di Django:
- scarichiamo per prima cosa nella nostra home l’ultima versione di django, utilizzando svn:
svn co http://code.djangoproject.com/svn/django/trunk/ django-src
- adesso rendiamo disponibile il path di django nella nostra installazione di python facendo un soft link:
ln -s ~/django_src/django ~/lib/python2.4/site-packages/django
- creiamo una directory nella vostra home che conterrà il progetto che andrete ad utilizzare:
mkdir ~/django_project
All’interno di questa directory dovrete caricare il vostro progetto django con tutte le cartelle ad eccezione della cartella media.
Rendiamoci visibili:
Nella vostra home oltre a tutte le cartelle che avete creato fin qui, ci dovrebbe essere una cartella con il nome uguale a quello del dominio che avete acquistato, in caso contrario vi consiglio di visitare il wiki di dreamhost per maggiori informazioni.
- Supponendo quindi che voi abbiate una cartella miodominio.com la prima cosa da fare è aggiungere le ultime due cartelle create nel PATH di sistema:
vim ~/.bashrc export PYTHONPATH=$PYTHONPATH:$HOME/django_src:$HOME/django_projects :wq source ~/.bashrc
- bisogna creare un file di configurazione che vi permetta di interfacciare il vostro progetto Django con il modulo fcgi:
vim ~/miodominio.com/django.fcgi #!/home/username/bin/python import sys sys.path += ['/home/username/django_src'] sys.path += ['/home/username/django_projects'] from flup.server.fcgi import WSGIServer from django.core.handlers.wsgi import WSGIHandler import os os.environ['DJANGO_SETTINGS_MODULE'] = 'Progetto.settings' WSGIServer(WSGIHandler()).run() :wq
ovviamente le parti con username e Progetto vanno sostituite con i vostri dati.
(N.B.) Fate molta attenzione ad utilizzare nano o vim come editor se hanno il wordwrap, perch� in questo caso le linee troppo lunghe verranno spezzate ed il file sar� inservibile. - ora va creato sempre nella directory miodominio.com il file che vi consentirà di utilizzare il mod_rewrite di Apache, quindi questo è quello che dovrete scrivere:
vim ~/miodominio.com/.htaccess RewriteEngine On RewriteBase / RewriteCond %{REQUEST_URI} ^/stats/(.*)$ [OR] RewriteRule ^.*$ - [L] RewriteRule ^(media/.*)$ - [L] RewriteRule ^(admin_media/.*)$ - [L] RewriteCond %{REQUEST_URI} !(django.fcgi) RewriteRule ^(.*)$ django.fcgi/$1 [L] :wqla riga
RewriteCond %{REQUEST_URI} ^/stats/(.*)$ [OR]sta ad indicare la parte di file nella quale dovrete inserire tutte le url che non debbono essere gestite da django, quindi ad esempio l’url per accedere alle statistiche del sito www.miodominio.com/stats
- gli ultimi ritocchi da fare sono:
ln -s ~/django_src/django/contrib/admin/media ~/miodomionio.com/admin_media
per rendere disponibile la grafica dell’amministrazione e caricare tramite ftp la cartella media del proprio progetto sempre dentro ~/miodominio.com
- Ormai giunti alla fine di questo lungo lavoro, dovrete modificare il file di configurazione di django, settings.py in modo tale che rispetti il nuovo ordinamento delle directory, in particolare vanno modificate tutte le linee che si riferiscono alla cartella media indicando dove queste vanno ricercate, cioè ~/miodominio.com:
MEDIA_ROOT = '/home/username/miodominio.com/media/' MEDIA_URL = 'http://www.miodominio.com/media/' ADMIN_MEDIA_PREFIX = '/admin_media/' TEMPLATE_DIRS = ( '/home/username/miodominio.com/media/template/', )
- Per concludere dovrete “uccidere” tutti i processi attivi con python e django, ricordate questo passaggio è necessario ripeterlo tutte le volte che modificherete un file vitale di django come settings.py o urls.py, digitate quindi:
killall -9 /home/username/bin/python killall -9 django.fcgi
Questo è veramente tutto, vi consiglio di leggere il tutorial su come utilizzare vim presente in questo blog all’indirizzo: http://www.antonellocicchese.com/2005/12/12/tutorial-vim/
ATTENZIONE: questa configurazione dopo i recenti aggiornamenti su dreamhost non è più consigliata, spesso causa crash nel sito che risulta irraggiungibile ritornando Errore 500, appena possibile pubblicherò una guida aggiornata…


