Ir al contenido principal

Instalación del módulo mysql-python en NAS Synology

Instalar gcc en Synology

Para la instalación de mysql-python es necesario el compilador gcc, por lo que lo obtendremos de Synology Open Source Project (http://sourceforge.net/projects/dsgpl). El paquete a descargar dependerá de la versión de NAS Synology que tengamos, por lo que tendremos que utilizara el comando:


uname -a


para conocer la versión de nuestro kernel y arquitectura instalada y descargar el paquete correspondiente. En mi caso he descargado: gcc463_glibc213_i686_cedarview-GPL.tgz pues mi equipo muestra cedarview y i686. Ahora lo descargamos y lo extraemos:


cd /usr/local
http://kent.dl.sourceforge.net/project/dsgpl/DSM%205.2%20Tool%20Chains/Intel%20x86%20Linux%203.2.40%20%28Cedarview%29/cedarview-gcc463_glibc213_i686_patched-GPL.txz
tar -xvJf cedarview-gcc463_glibc213_i686_patched-GPL.txz
rm
cedarview-gcc463_glibc213_i686_patched-GPL.txz


Instalación de las fuentes de Mysql

Synology utiliza MariaDB, pero para la compilación del módulo de python podemos utilizar las fuentes de Mysql. Descargaremos la versión que coincida con la que ya tenemos instalada.

cd /volume1
wget -nd http://cdn.mysql.com/Downloads/MySQL-5.5/mysql-5.5.39-linux2.6-i686.tar.gz
gzip -d mysql-5.5.39-linux2.6-i686.tar.gz
tar -xvf mysql-5.5.39-linux2.6-i686.tar
rm mysql-5.5.39-linux2.6-i686.tar


Necesitamos mysql_config que no está en el NAS.


ln -s /volume1/mysql-5.5.39-linux2.6-i686/bin/mysql_config /usr/bin/mysql_config

Instalación de pip

Descarga e instalación:

wget -nd https://bootstrap.pypa.io/get-pip.py
python get-pip.py


Instalación de mysql-python

Tenemos que definir todas estas variables de entorno para que se adapte al compilador y las fuentes de Mysql que hemos instalado, por lo que será necesario modificarlas para que se adapten a nuestra configuración:


export CROSS_PREFIX=i686-pc-linux-gnu
export TARGET=i686-pc-linux-gnu
export TOOLCHAIN=/usr/local/i686-pc-linux-gnu
export AR=${TOOLCHAIN}/bin/${CROSS_PREFIX}-ar
export AS=${TOOLCHAIN}/bin/${CROSS_PREFIX}-as
export CC=${TOOLCHAIN}/bin/${CROSS_PREFIX}-gcc
export CXX=${TOOLCHAIN}/bin/${CROSS_PREFIX}-g++
export LD=”${TOOLCHAIN}/bin/${CROSS_PREFIX}-ld”
export LDSHARED="${TOOLCHAIN}/bin/${CROSS_PREFIX}-gcc -shared "
export RANLIB=${TOOLCHAIN}/bin/${CROSS_PREFIX}-ranlib
export CFLAGS="-I${TOOLCHAIN}/include -O3 ${MARCH} -I/opt/include/python2.6/ -I/volume1/mysql-5.5.39-linux2.6-i686/include"
export LDFLAGS="-L${TOOLCHAIN}/lib -L/lib/"
export PKG_CONFIG_PATH="${TOOLCHAIN}/lib/pkgconfig"

Finalmente  procedemos a la instalación:

pip install mysql-python

Comentarios

Entradas populares de este blog

Instalación Django en NAS Synology con FastCGI

Los NAS Synology no traen el módulo de apache mod-wsgi por lo que he utilizado el módulo mod-fastcgi en su lugar para hacer funcionar Django en los NAS Synology. Necesitamos del módulo mysql-python , para su instalación podemos seguir la entrada que ya se publicó en este mismo blog:  http://ilizaran.blogspot.com.es/2014/09/instalacion-del-modulo-mysql-python-en.html De la instalación de mysql-python ya tendremos instalado pip en el NAS por lo que podremos instalar Django con algunos módulos necesarios: pip install Django pip install setuptools pip install flup Para saber que la instalación de Django ha sido correcta y verificar la versión podemos realizar: python import django  django.VERSION Ahora modifcamos la configuración de apache editando el fichero /etc/httpd/conf/httpd.conf-user  para hacer accesible los ficheros css, imágenes y javascript de la parte administrativa de Django, por lo que añadimos: Alias /static/admin /usr/local/packages/@appstore/Python/usr/l

Calcular en Mysql el primer y último día del mes

SELECT DATE_FORMAT(now(),'%Y-%m-01') AS first_day; SELECT date_add(date_add(LAST_DAY(now()),interval 1 DAY),interval -1 MONTH) AS first_day; SELECT LAST_DAY(now()) AS last_day; Calcular en Mysql el primer y último día del mes anterior: SELECT date_add(date_add(LAST_DAY(now()),interval 1 DAY),interval -2 MONTH) AS first_day; SELECT LAST_DAY(date_add(last_day(now()),interval -1 MONTH)) AS last_day;