Posted on March 2, 2015
Montar Proyecto Symfony con Git en servidor Centos
Vamos a dar de alta el proyecto Symfony con composer en nuestra carpeta /var/www/html de nuestro servidor, por defecto apache la coloca ahí pero pudiera darse el caso de tenerla en otra ubicación.
Para instalar composer ejecutamos las siguientes instrucciones:
1 2 |
curl -sS https://getcomposer.org/installer | php sudo mv composer.phar /usr/local/bin/composer |
Con esto deberiamos tener activo el comando composer, ahora creamos el proyecto symfony en la capeta www:
1 |
composer create-project symfony/framework-standard-edition proyecto_prueba |
De esa manera empezará la instalación y pedirá algunas opciones de configuración, al finalizar deberías tener la carpeta proyecto_prueba con todos los archivos descargados.
Vamos a pasar nuestro proyecto como repositorio Git, para esto debemos tener Git instalado en el servidor, si no es así sólo ejecuta:
1 |
yum install git |
Una vez instalado vamos a inicializar nuestro repositorio desde la capeta del proyecto:
1 |
cd /var/www/html/proyecto_prueba |
Antes de inicializar el repositorio vamos a renombrar un archivo que es .gitignore, y lo puedes ver en el listado de archivos de proyecto, el parámetro -a es para vel los archivos ocultos:
1 |
ls -a |
Ese archivo lo vamos a renombrar a .gitignore_copy, esto es porque cuando creamos el repositorio omite los archivos que vienen en el contenido de .gitignore y no queremos eso, lo que se pretende es hacer el repositorio del proyecto completo:
1 |
mv .gitignore .gitignore_copy |
Ahora si, inicializamos nuestro repositorio, dentro del proyecto ejecutamos:
1 |
git init |
Luego añadimos todos los archivos al repositorio:
1 |
git add . |
Hacemos el commit para mandar los archivos agregados y el mensaje con la descripción del commit con el parámetro -m.
1 |
git commit -m "Inicializacion Repositorio" |
Con esto tenemos el repositorio listo, pero hay un detalle, este repositorio no lo podemos clonar, para ellos necesitamos un repositorio conocido como “repositorio bare”, este es el que nos va a permitir hacer esto, y se crea a partir del repositorio que acabamos de inicialzar, entonces con el repositorio recien creado ejecutamos:
1 |
git clone --bare /var/www/html/proyecto_prueba /proyecto_prueba.git |
El repositorio proyecto_prueba.git lo creamos en la raiz del servidor, además es buena practica que el repositorio bare tenga la terminación “.git” para identificarlo más facilmente, si exploramos esta carpeta veremos archivos y carpetas como: branches, hooks, info, objects. Más adelante haremos uso de una de estas carpetas para poder identificar los cambios que se hagan en el repositorio.
Con esto finalizamos la creación del repositorio, podremos clonarlo desde cualquier equipo cliente en un entorno de desarrollo como Eclipse o NetBeans, internamente estos IDE´s ejecutan el comando:
1 |
git clone ssh://usuario@dominio.com:22/proyecto_prueba.git |
Muchas veces cuando se trabajo en un ambiente web, se requiere que los cambios hechos en el repositorio también se vean reflejados en el servidor donde se encuentra el proyecto en la www, para ello hay que clonar el repositorio bare en la www e indicar en los hooks del repositorio bare que cuando haya cambios los replique al repositorio que se encuentra en la www.
Para ello debemos clonar el repositorio bare en nuestra carpeta www, pero antes vamos a borrar la carpeta original donde inicializamos nuestro primer repositorio del cual generamos el bare.
1 |
rm -rf /var/www/proyecto_prueba |
Los parámetros -rf son para que el borrado sea recursivo y la “f” para forzarlo.
Ahora si clonamos el repositorio en la www:
1 |
git clone /proyecto_prueba.git /var/www/html/proyecto_prueba |
El siguiente paso es detectar los cambios que se hacen en el repositorio bare para mandarlos al nuevo repositorio que esta en la www, lo que se tiene que hacer es ir a la carpeta del repositorio proyecto_prueba.git y dentro hay una carpeta llamada hooks, en esa carpeta vamos a crear un archivo que se llamara post-update:
1 2 |
cd /proyecto_prueba.git/hooks nano post-update |
Si no tienes nano lo puedes instalar con la instrucción:
1 |
yum install nano |
Escribe el siguiente contenido en el archivo post-update:
1 2 3 4 5 6 |
#!/bin/bash WEB_DIR="/var/www/html/proyecto_prueba" export GIT_DIR="$WEB_DIR/.git" pushd $WEB_DIR > /dev/null git pull popd > /dev/null |
Una breve explicación del archivo, se declara una constante WEB_DIR con la ruta del proyecto en la www, GIT_DIR ahora hará referencia a esta carpeta, pushd nos coloca sobre el directorio del repositorio y se hace el pull para bajar los últimos cambios del repositorio bare, al finalizar quitamos de la pila el $WEB_DIR del pushd anterior.
Guardamos el archivo “control+x” si estás en windows y asignamos permisos de ejecución al archivo:
1 |
chmod 755 post-update |
Con estos pasos se deberían reflejar los cambios cada vez que se hacen modificaciones en el repositorio bare, el script post-update se ejecutara actualizando los archivos en el repositorio que esta en la www, así las personas que tengan el repositorio clonado en cada una de sus máquinas cuando manden sus cambios al repositorio con push también el repositorio que se encuentra en la www será actualizado.