The deployment strategy used at amazee.io for production is heavily inspired by capistrano.
home directory (like /var/www/site_name)
├── public_html -> /var/www/site_name/releases/20160607095555Z/
├── releases
│ ├── 20160612075028Z
│ ├── 20160607095542Z
│ └── 20160607095555Z
├── repo
│ └── <GIT repo>
└── shared
└── <shared directories>
public_html
is a symlink pointing to the latest release. This symlink is updated after thebefore_deploy
tasks are executed. If the deployment fails before or during execution ofbefore_deploy
tasks the symlink is not touched and still points to the old release.releases
holds all deployments in a timestamped folder in UTC. These folders are the target of the current symlink. We keep 3 release folders present, the older folders get deleted after a successful deploymentrepo
holds a checkout of the configured git repository.shared
contains directories which are symlinked into each release. This data persists across deployments and releases. It is used for things like the Drupal files directory.
This shows the order of a production deployment. If on a cluster stack, these tasks are all executed simultaneously at the same time on all backends:
- The git repo inside
repo
is checked out to the desired git branch (basically agit pull
) - The whole folder
repo
is copied into thereleases
folder, with the folder name of the current time in UTC. - The
before_deploy
tasks are executed inside the created folder.
- Important:
before_deploy
tasks should only be used for tasks that do not change anything on the Drupal Database and for tasks that need to be executed on all servers within a cluster. Some examples:composer install
,npm
- If any of these
before_deploy
tasks failed (return code is not 0), the deployment is stopped immediately and the created directory for the failed deployment within thereleases
directory is removed.
- The
public_html
symlink is switched to the new folder withinreleases
- This is referred to as the actual deploy. (this why the tasks are called
before
andafter
deploy tasks)
- The
after_deploy
tasks are executed (if on cluster only on one backend!).
- Important:
after_deploy
tasks should be used for tasks that change database related things likedrush updb
or for tasks that should be executed only once in a cluster environment, likedrush cr
. - If any of the
after_deploy
tasks failed (return code is not 0), the rollback routine is called on all backends:- The
public_html
symlink is changed back to the previous deployment. - The
releases
folder of the failed deployment is removed.
- No tasks from the
before_deploy
orafter_deploy
task lists are executed, as the state of the Drupal site is very hard to understand for the deployment system. In case of a rollbacked deployment, you should ensure yourself that the site is working properly.
- The
Development sites do not need a complex deployment system and are therefore easier. Basically it's just a git pull directly on the public_html
directory and deployment tasks executed.
home directory (like /var/www/site_name)
└── public_html
public_html
is a git checkout of the desired git branch
There are no additional directories, everything is within public_html
- The git repository inside
public_html
is checked out to the desired git branch (basically agit pull
) - The
before_deploy
tasks are executed inside thepublic_html
folder.
- If any of these
before_deploy
tasks failed (return code is not 0), the deployment is stopped immediately, no rollback to the previous deployment is happening.
- The
after_deploy
tasks are executed.
- If any of the
after_deploy
tasks failed (return code is not 0), the deployment is stopped immediately, no rollback to the previous deployment is happening