Déploiement d'application Symfony en production avec git

Assumptions

Partons du principe que l’on déploie, en production, dans /var/www/mon_app
Que la gestion des dépôts git à été faite sous gitolite.
L’user de déploiement est publisher.
Enfin dans git, on à deux branches (entre autre), une dans laquelle, master, on verse les modifications à mettre en production, et une production, qui contient les commits avec la configuration de production, que l’on rebase sur master avant de la pousser.

Préparation / Mise en place

On créé initialise donc le dépôt git :

git init

Depuis le poste du déployeur, on ajoute une branche production.

git branch production

On y fait les modifications pour la production (paramaeters.ini entre autre) et on commit.
Ensuite quand des modifications seront faite sur le master, il suffira de ce remettre à jour :

git rebase master

Une fois cela fait il faut, initialiser la copie en production :
On récupère composer :

php -r “eval(‘?>’.file_get_contents(‘https://getcomposer.org/installer'));"

Et on lance l’initialisation des bundles :

./composer.phar update

Pour pouvoir déployer il faut avant tout ajouter la cible de déploiement pour la mise en prod :

git remote add prod publisher@srv1.domain.tld:/var/www/mon_app

Ne pas oublier de ce mettre sur la branche production en … production.

git checkout production

Pour que le commit puisse fonctionner il faut définir :

git config receive.denyCurrentBranch ignore

Puis dans un second temps, mettre en place un hook git pour initialiser l’application symfony2.
On utilise le hook post-update c’est à dire, une fois que le dépôt à reçu la mise à jour du code.

#!/bin/sh
#

This hook does three things:

#

1. update the “info” files that allow the list of references to be

queries over dumb transports such as http

#

2. if this repository looks like it is a non-bare repository, and

the checked-out branch is pushed to, then update the working copy.

This makes “push” function somewhat similarly to darcs and bzr.

#

3. clear the symfony cache, update submodules and install static assets

#

To enable this hook, make this file executable by “chmod +x post-update”.

export SYMFONY_ENV=prod PHP=“php -c /etc/php5/fpm/php.ini” CONSOLE=“$PHP app/console –no-debug”

git-update-server-info

is_bare=$(git-config –get –bool core.bare)

if [ -z “$is_bare” ] then # for compatibility’s sake, guess git_dir_full=$(cd $GIT_DIR; pwd) case $git_dir_full in */.git) is_bare=false;; *) is_bare=true;; esac fi

update_wc() { ref=$1 echo “Push to checked out branch $ref” >&2 if [ ! -f $GIT_DIR/logs/HEAD ] then echo “E:push to non-bare repository requires a HEAD reflog” >&2 exit 1 fi if (cd $GIT_WORK_TREE; git-diff-files -q –exit-code >/dev/null) then wc_dirty=0 else echo “W:unstaged changes found in working copy” >&2 wc_dirty=1 desc=“working copy” fi if git diff-index –cached HEAD@{1} >/dev/null then index_dirty=0 else echo “W:uncommitted, staged changes found” >&2 index_dirty=1 if [ -n “$desc” ] then desc=“$desc and index” else desc=“index” fi fi if [ “$wc_dirty” -ne 0 -o “$index_dirty” -ne 0 ] then new=$(git rev-parse HEAD) echo “W:stashing dirty $desc - see git-stash(1)” >&2 ( trap ‘echo trapped $$; git symbolic-ref HEAD “’”$ref”‘“’ 2 3 13 15 ERR EXIT git-update-ref –no-deref HEAD HEAD@{1} cd $GIT_WORK_TREE git stash save “dirty $desc before update to $new”; git-symbolic-ref HEAD “$ref” ) fi

# eye candy - show the WC updates 
echo "Updating working copy" >&2
(cd $GIT_WORK_TREE
git-diff-index -R --name-status HEAD >&2
git-reset --hard HEAD)

# install / update vendor bundles
echo "Installing vendor bundles" >&2
(cd $GIT_WORK_TREE
git-submodule sync
git-submodule update --init)

# bootstrap symfony
echo "Bootstraping Symfony" >&2
(cd $GIT_WORK_TREE
$PHP vendor/bundles/Sensio/Bundle/DistributionBundle/Resources/bin/build_bootstrap.php)

# Clear the symfony cache
echo "Clearing the symfony cache" >&2
(cd $GIT_WORK_TREE
$CONSOLE cache:clear --no-warmup)

# Deploy static assets
echo "Installing static assets" >&2
(cd $GIT_WORK_TREE
$CONSOLE assetic:dump --no-debug
$CONSOLE assets:install --symlink web)

}

if [ “$is_bare” = “false” ] then active_branch=git-symbolic-ref HEAD export GIT_DIR=$(cd $GIT_DIR; pwd) GIT_WORK_TREE=${GIT_WORK_TREE-..} for ref do if [ “$ref” = “$active_branch” ] then update_wc $ref fi done fi