Configurar un blog con Zinna y Django en Nitrous.IO

Archivada en Desarrollo

Configurar un blog con Zinna y Django en Nitrous.IO

Ya vimos como crear un entorno de programación en Nitrous.IO, ya creamos nuesra base de datos PostgreSQL en Heroku, por lo que estamos listos para crear nuestro blog. Antes de entrar de lleno con el blog, vamos a asegurar que nuestro entorno virtual cuenta con todos los requisitos para poder operar con él.

Intalación de requisitos

Recuerda que tenemos un entorno virtual y por lo tanto, debe estar activado.

javier@krypton:~$ workon krypton
/bin/bash: warning: setlocale: LC_ALL: cannot change locale (es_MX.UTF-8)
/bin/bash: warning: setlocale: LC_ALL: cannot change locale (es_MX.UTF-8)
(krypton)javier@krypton:~$

La conexión con PostgreSQL

Ya que nuestra base de es PostgreSQL, vamos a instalar el módulo psycopg2 que es el estándar para Django. Con nuestro entorno virtual activado, usamos pip para instalarlo.

(krypton)javier@krypton:~$ pip install psycopg2
Downloading/unpacking psycopg2
  Downloading psycopg2-2.5.2.tar.gz (685kB): 685kB downloaded
  Running setup.py egg_info for package psycopg2

Installing collected packages: psycopg2
  Running setup.py install for psycopg2
    building 'psycopg2._psycopg' extension
    gcc -pthread -fno-strict-aliasing -DNDEBUG -g -fwrapv -O2 -Wall -Wstrict-prototypes -fPIC -DPSYCOPG_DEFAULT_PYDATETIME=1 -DPSYCOPG_VERSION="2.5.2 (dt dec pq3 ext)" -DPG_VERSION_HEX=0x090204 -DPSYCOPG_EXTENSIONS=1 -DPSYCOPG_NEW_BOOLEAN=1 -DHAVE_PQFREEMEM=1 -I/usr/include/python2.7 -I. -I/usr/include/postgresql -I/usr/include/postgresql/9.2/server -c psycopg/psycopgmodule.c -o build/temp.linux-x86_64-2.7/psycopg/psycopgmodule.o -Wdeclaration-after-statement

[--- Luego de muchos otras líneas, llegamos al final ---]

Successfully installed psycopg2
Cleaning up...

Este módulo compila el controlador usando las librerías de PostgreSQL, que tienen que estar presentes, así como los programas de desarrollo, como g++, make y otros.

En Nitrous.IO tienes un entorno completo

Afortunadamente, en [Nitrous.IO] no tienes que preocuparte, porque tienes todos los programas y librerías instalados, así que olvídate de referencias incompletas.

Zinnia, la elección del blog

En namespace.mx el código del blog está escrito por mi completamente, pero la realidad es que no es el mejor y sobre todo porque reinventaba la rueda. Claro que el objetivo es aprender, y con ese mismo espíritu de aprendizaje es que ahora tomo un código profesional para avanzar en mi aprendizaje personal.

Entonces el blog elegido es Zinnia. Se define como una aplicación extensible para administrar blogs. Y es bastante ligero, ya que como ellos mismos dicen, cualquier módulo que pudo ser manejado por otra aplicación se ha dejado de lado.

El autor de de Zinnia es el francés Fantomas42 que ha hecho excelentes contribuciones a Python, además de Zinnia.

Dependencias de Zinnia

Revisando las dependencias de Zinnia, vemos que necesitamos los módulos Pyllow, django-mptt1, django-tagging y beautifulsoup4. De forma opcional, enlista pytz, South, pyparsing y django-xmlrpc.

Para instalar estas dependencias más facilmente vamos a crear un archivo llamado requirements.txt2 con todos estos módulos.

Solo hay una acotación en esta lista. El módulo Pyllow tiene que ser instalado usando easy_install

El proyecto Krypton

Ahora si, empezamos con el proyecto krypton en el desarrollaremos un blog para hablar de criptomonedas, como Bitcoin, Litecoin, Quarkcoin, las famosas cryptos, de ahí el nombre del proyecto.

Empezamos creando un subdirectorio desde nuestro IDE en Nitrous.IO, y lo llamaremos proyecto_krypton.

mkdir proyecto_krypton

y dentro creamos un archivo, con nuestro IDE o con vim llamado requirements.txt con el siguiente contenido:

Django==1.6.1
Pillow==2.3.0
South==0.8.4
argparse==1.2.1
beautifulsoup4==4.3.2
django-mptt==0.6.0
django-tagging==0.3.1
django-xmlrpc==0.1.5
psycopg2==2.5.2
pyparsing==2.0.1
pytz==2013.9
wsgiref==0.1.2

Es muy importante aclarar que este archivo de dependencias no es estático. Si mañana agregamos un nuevo módulo podemos actualizar este archivo de forma muy fácil con el comando pip freeze > requirements.txt.

Instalación de Zinnia

Vamos a instalar Zinnia directamente desde las fuentes en GitHub usando también pip, como no.

(krypton)javier@krypton:~$ pip install -e git://github.com/Fantomas42/django-blog-zinnia.git#egg=django-blog-zinnia
Obtaining django-blog-zinnia from git+git://github.com/Fantomas42/django-blog-zinnia.git#egg=django-blog-zinnia
  Cloning git://github.com/Fantomas42/django-blog-zinnia.git to ./entornos/krypton/src/django-blog-zinnia
  Running setup.py egg_info for package django-blog-zinnia

[--- Muchas líneas mas ---]

    Adding django-blog-zinnia 0.14.dev to easy-install.pth file

    Installed /home/action/entornos/krypton/src/django-blog-zinnia
Successfully installed django-blog-zinnia
Cleaning up...

La estructura del proyecto

Esto es importante, vamos a usar una estructura que permita exportar el proyecto a repositorios de control de fuentes o usar aplicaciones de sincronización como la que usa Nitrous.IO y de hecho, ya tenemos nuestro primer nivel que es proyecto_krypton. Esta es la estructura propuesta, que es un estándar en los proyectos de desarrollo en Django.

  1. Proyecto Krypton
    1. Directorio de Django para el proyecto
      1. Configuracion
      2. Blog
      3. Utilerias
      4. Ticker
      5. Foro
      6. Plantillas
      7. Foundation
      8. Media
    2. Documetancion

Ahora toca crear el proyecto de Django, dentro del directorio del proyecto.

(krypton)javier@krypton:~$ cd proyecto_krypton/
(krypton)javier@krypton:~/proyecto_krypton$ django-admin.py startproject krypton
(krypton)javier@krypton:~/proyecto_krypton$ cd krypton/

Esto instala el esqueleto básico pero funcional de un proyecto en Django, y podemos verificar que todo funciona ejecutando el servidor de pruebas.

(krypton)javier@krypton:~/proyecto_krypton/krypton$ python manage.py runserver 0.0.0.0:8000
Validating models...

0 errors found
January 12, 2014 - 04:51:26
Django version 1.6.1, using settings 'krypton.settings'
Starting development server at http://0.0.0.0:8000/
Quit the server with CONTROL-C.

Es importante que agregues 0.0.0.0:8000 a la línea de comandos para que puedas ver el proyecto en tu navegador, usando la dirección que aparece en Preview URI en la configuración de tu caja.

Y dejamos aquí este artículo, pero antes vamos a hacer un repaso de lo que tenemos hasta este punto.

  • Configuramos un caja en Nitrous.IO, con lo que tenemos un servidor de alto desempeño con 512 Mb de memoria y 1000 Mb de espacio. Lee este artículo “Cómo desarrollar una aplicación con Nitrous.IO
  • Creamos una base de datos PostgreSQL de alta disponibilidad en la red Heroku y configuramos las variables de conexión en nuestra caja: “Configurar PostgreSQL en Heroku”
  • Instalamos Django y todas las dependencias para ejecutar el motor de nuestro blog que es Zinnia, también configuramos la estructura básica de nuestro proyecto y probamos que el servidor tenga salida a Internet.

  1. django-mptt es un módulo para crear árboles de datos transversales preordenados. No tengo idea que signifique eso, pero ya nos enteraremos más adelante. 

  2. El nombre del archivo puede ser cualquiera, por ejemplo requisitos.txt, pero es un estándar y seguir los estándares es una buena práctica. 

Javier Sanchez Toledano

Soy programador en Django+Python y WordPress. Auditor líder certificado en la norma ISO 9001:2008. Fotógrafo aficionado.
Redes Sociales:

Tlaxcala, México

Comentarios