<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>AntonelloCicchese.com &#187; Django</title>
	<atom:link href="http://www.antonellocicchese.com/category/python/django/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.antonellocicchese.com</link>
	<description></description>
	<lastBuildDate>Wed, 28 Apr 2010 20:19:11 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9.2</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Django e Python su DreamHost.com</title>
		<link>http://www.antonellocicchese.com/2006/10/12/django-python-dreamhost/</link>
		<comments>http://www.antonellocicchese.com/2006/10/12/django-python-dreamhost/#comments</comments>
		<pubDate>Thu, 12 Oct 2006 10:21:04 +0000</pubDate>
		<dc:creator>antonello</dc:creator>
				<category><![CDATA[Django]]></category>
		<category><![CDATA[Guide]]></category>
		<category><![CDATA[Python]]></category>
		<category><![CDATA[WebMaster]]></category>

		<guid isPermaLink="false">http://www.antonellocicchese.com/2006/10/12/django-e-python-su-dreamhostcom/</guid>
		<description><![CDATA[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&#8230;

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 [...]]]></description>
			<content:encoded><![CDATA[<p><strong><em>ATTENZIONE</em>: 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&#8230;<br />
</strong></p>
<p>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&#8217;indirizzo:<br />
<a target="_blank" href="http://forums.site5.com/showthread.php?t=10236"> http://forums.site5.com/showthread.php?t=10236</a><br />
ora non mi rimane che augurarvi una buona lettura.</p>
<p>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:</p>
<ol>
<li>collegatevi in ssh sul vostro server</li>
<li>una volta entrati nella vostra home digitate:
<pre lang="c">wget http://peak.telecommunity.com/dist/virtual-python.py
python virtual-python.py</pre>
<p>Questo creerà  nella vostra home diverse cartelle (bin, lib, &#8230;) che vi consentiranno di avere una installazione personalizzata di python.<br />
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.</li>
<li>Adesso è necessario scaricare ez_setup:
<pre lang="c">wget http://peak.telecommunity.com/dist/ez-setup.py
~/bin/python ez_setup.py</pre>
<p>Adesso avete un&#8217;installazione completamente funzionante di python al vostro servizio, passiamo ora all&#8217;installazione delle librerire necessarie.</li>
</ol>
<p><strong>Librerie di python:</strong></p>
<ol>
<li>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&#8217;ultima versione della libreria che trova a questo indirizzo  <a target="_blank" href="http://sourceforge.net/projects/mysql-python">http://sourceforge.net/projects/mysql-python</a> 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.
<pre lang="c">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</pre>
</li>
<li>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):
<pre lang="c">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</pre>
</li>
<li>Installiamo infine la libreria flup:
<pre lang="c">svn co http://svn.saddi.com/flup/trunk flup
cd flup
~/bin/python setup.py install</pre>
<p>a questo punto siete pronti per l&#8217;installazione vera e propria di Django.</li>
</ol>
<p><strong>Installazione di Django:</strong></p>
<ol>
<li>scarichiamo per prima cosa nella nostra home l&#8217;ultima versione di django, utilizzando  svn:
<pre lang="c">svn co http://code.djangoproject.com/svn/django/trunk/ django-src</pre>
</li>
<li>adesso rendiamo disponibile il path di django nella nostra installazione di python facendo un soft link:
<pre lang="c">ln -s ~/django_src/django ~/lib/python2.4/site-packages/django</pre>
</li>
<li>creiamo una directory nella vostra home che conterrà il progetto che andrete ad utilizzare:
<pre lang="c">mkdir ~/django_project</pre>
<p>All&#8217;interno di questa directory dovrete caricare il vostro progetto django con tutte le cartelle ad eccezione della cartella media.</li>
</ol>
<p><strong>Rendiamoci visibili:</strong></p>
<p>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.</p>
<ol>
<li>Supponendo quindi che voi abbiate una cartella miodominio.com la prima cosa da fare è aggiungere le ultime due cartelle create nel PATH di sistema:
<pre lang="c">vim ~/.bashrc
export PYTHONPATH=$PYTHONPATH:$HOME/django_src:$HOME/django_projects
:wq
source ~/.bashrc</pre>
</li>
<li>bisogna creare un file di configurazione che vi permetta di interfacciare il vostro progetto Django con il modulo fcgi:
<pre lang="python">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</pre>
<p>ovviamente le parti con <strong><em>username</em></strong> e <strong><em>Progetto</em></strong> vanno sostituite con i vostri dati.<br />
<strong> (N.B.)</strong> 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.</li>
<li>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:
<pre lang="c">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]  

:wq</pre>
<p>la riga</p>
<pre lang="c">RewriteCond %{REQUEST_URI} ^/stats/(.*)$ [OR]</pre>
<p>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&#8217;url per accedere alle statistiche del sito <em>www.miodominio.com/stats</em></li>
<li>gli ultimi ritocchi da fare sono:
<pre lang="c">ln -s ~/django_src/django/contrib/admin/media ~/miodomionio.com/admin_media</pre>
<p>per rendere disponibile la grafica dell&#8217;amministrazione e caricare tramite ftp la cartella media del proprio progetto sempre dentro ~/miodominio.com</li>
<li>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:
<pre lang="c">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/',  )</pre>
</li>
<li>Per concludere dovrete &#8220;uccidere&#8221; 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:
<pre lang="c">killall -9 /home/username/bin/python
killall -9 django.fcgi</pre>
</li>
</ol>
<p>Questo è veramente tutto, vi consiglio di leggere il tutorial su come utilizzare vim presente in questo blog all&#8217;indirizzo:  <a title="Tutorial Vim" href="http://www.antonellocicchese.com/2005/12/12/tutorial-vim/">http://www.antonellocicchese.com/2005/12/12/tutorial-vim/</a></p>
<p><strong><em>ATTENZIONE</em>: 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&#8230;<br />
</strong></p>
]]></content:encoded>
			<wfw:commentRss>http://www.antonellocicchese.com/2006/10/12/django-python-dreamhost/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
