Concourse is a continuous integration and continuous deployment system similar to Jenkins.
The Reliability Engineering team runs a hosted Concourse service for all GDS teams.
Concourse is built on the concept of pipelines. Each pipeline can be compared to a collection of related Jenkins jobs. Pipelines consist of multiple jobs and resources. Jobs are collections of commands that are run, and are stateless since they are run inside disposable Docker containers. All state needs to be stored and read from resources, which may be a git repository, an AWS S3 bucket or another storage medium. Triggers allow changes to resources to start a job, and jobs can trigger other jobs.
GOV.UK currently has one team named govuk-tools.
To view pipelines within this Concourse team, you need to be a member of the GOV.UK GitHub team. To change pipelines within this Concourse team, you need to be a member of the GOV.UK Production GitHub team.
What pipelines do we currently have?
The coronavirus forms pipelines
More information about these can be found on the docs page for the forms.
The operations pipeline
We currently use the
operations pipeline to mirror all GOV.UK GitHub repositories to AWS CodeCommit.
The info pipeline
info pipeline is a meta pipeline. Its main use is as a method to store secrets that can then be used in other pipelines. For example, the repository mirroring job uses GitHub and AWS credentials that are stored as secrets using this method. How to add and remove secrets is documented in the Reliability Engineering manual.
Creating new pipelines
The above pipelines serve as good examples for how to do continuous deployment and scheduled tasks with Concourse.
Whenever a pipeline YAML is created or changed, it needs to be applied for the changes to take effect.
Some of our Concourse pipelines use the beta Concourse "self-update" feature that runs a task whenever a change to the pipeline YAML is merged to master. For others, like the repo mirroring job, or if you're writing a new Concourse pipeline, you have to run
fly set-pipeline manually:
- If this is your first time using Concourse, download the
flyCLI by clicking the appropriate OS logo at the bottom right corner of the team page and move it to somewhere in your
$PATH. If that doesn't download an executable file, try
brew cask install fly.
- Set a target for the team you want to login to:
fly login -c https://cd.gds-reliability.engineering -n govuk-tools -t cd-govuk-tools
- Navigate to the folder that contains the pipeline config YAML file
fly -t cd-govuk-tools set-pipeline -p [pipeline name] -c [pipeline config YAML file name]
- Visit the provided URL to log in
- Double-check the diff to ensure you're happy with what is about to be applied
yto make the changes