/gitlab-ci-deploy

Reusable config for simple, SSH based deploys using GitLab CI

MIT LicenseMIT

gitlab-ci-deploy

Latest Stable Version Total Downloads License

Reusable config for simple, SSH based deploys using GitLab CI/CD.

Requirements

  • A server with SSH access, bash & rsync
  • A repository hosted on Gitlab with the following files: .gitlab-ci and .deploy/.rsync-filter. The examples can be used for inspiration.

Features

Run pipelines using GitLab CI/CD

All this functionality is powered by GitLab CI/CD, check their documentation for more information.

Deploy your files using rsync

The deployment of your files is done using rsync:

  • One-way sync, left to right
  • Extraneous files are deleted from destination dirs
  • Filter rules can be defined in the .deploy/.rsync-filter file.

To minimise downtime, the file sync will happen to a copy of your files in a new release. After finishing the sync, the active release will be changed by replacing the symlink. A couple of settings can be changed through variables:

  • RELEASES_FOLDER: the name of the folder in which all releases are stored (default: releases)
  • CURRENT_RELEASE_FOLDER: the name of the folder to which the active release is symlinked (default: current)
  • KEEP_RELEASES: the amount of releases that should be kept (minimum: 1, default: 2)

A couple environment variables are required, check the documentation for ways to define them.

  • DEPLOY_SERVER_HOST: the host of the server
  • DEPLOY_SERVER_USER: the user used for SSH'ing
  • DEPLOY_SSH_PRIVATE_KEY: the private key used for SSH'ing
  • DEPLOY_PATH: the path the files should be deployed to

Run a server-side script after deploy

If a .deploy/post-deploy.sh file exists, it will be executed on the server after the deployment is finished. The current directory will be equal to DEPLOY_PATH.

Automatically generate .env files

A script is provided to automatically generate a .env file and serve it as an artifact in your pipeline. To add this functionality to your pipeline, create a new job extending .create_dotenv:

dotenv:
  extends:
    - .create_dotenv
  stage: build

The script will take a .env.example file as starting point and fill in the values using current environment variables. There are multiple ways to define your environment variables, check the documentation for more information.

Create a Sentry release

A script is provided to create a new Sentry release. To add this functionality to your pipeline, create a new job extending .create_sentry_release and make sure SENTRY_AUTH_TOKEN, SENTRY_DSN, SENTRY_ORG and SENTRY_PROJECT are available as environment variables. Please refer to the Sentry CLI docs for more information.

Examples

Some examples are provided to get you started quickly.

  • simple, deploy-only setup
  • Drupal 8 website
  • jobs for building a custom theme, .env file, installing Composer dependencies and creating a Sentry release after deploying
  • a set of Drush commands are executed after deploying.
  • OctoberCMS website
  • jobs for building a custom theme, .env file and installing Composer dependencies
  • a set of Artisan commands are executed after deploying.
  • staging environment which is automatically built and deployed after pushing to a Gitflow-style release branch
  • production environment which is automatically built, but manually deployed after pushing a Semantic Versioning-style tag.