GitLab
GitLab is a web-based “dev ops” software system that provides Git server based hosting, bug tracking, CICD and more for software projects. It is a strong competitor to GitHub, especially for commercial uses.
Container Registries
Each repo can have it’s own container registry. You can use this to store Docker images relating to the project.
CI_REGISTRY_IMAGE
is provided and is the base path for the container registry.
You can log into the repo’s container registry inside a pipeline with the command:
Then you be able to push a built image:
You can download images from the GitLab container registry to your local machine by first logging in:
You will be prompted to enter your username and password. If you have 2FA enabled, you will have to substitute your password with a personal access token.
You can then download and run an image with:
GitLab CI Files
Includes
You can include files in your .gitlab-ci.yml
file with the include
keyword. This is useful for sharing common configuration between multiple projects.
You can also use the ref
to specify a branch, tag or commit SHA when including a file. This is good for “version control” of your include dependencies.
Conditionally Running Jobs
Sometimes you will only want to run a job under certain conditions. You can do this by using the rules
keyword.
Regex can be used with the rules
keyword by using =~
.
Running Jobs In Docker Containers
You can tell GitLab to run the job inside a Docker container by using the image
keyword.
The default Docker user will be used by default. If you want to override this, you can change the structure of the image
key a bit and add a docker
/user
key as shown below.
Running Pipelines Locally
GitLab does not have official support for running pipelines locally, but there is a popular third-party tool called gitlab-ci-local (a.k.a. GCL) which allows you to do this.
Installation
To install gitlab-ci-local
on Debian-based UNIX distributions (e.g. Ubuntu), you can run the following command2:
Running a Job
Clone the repository that contains the pipeline (i.e. has a .gitlab-ci.yml
file) and run the following command:
This will run the job locally and output the results to the console. You may need authentication for the job to run successfully, see the section below for details.
However, this will not run the job’s dependencies, which might be what you were expecting. To run the job and all of it’s dependencies, add the --needs
flag:
gitlab-ci-local
will cache the “dot env” of dependencies, so you don’t need to keep using --needs
during testing if the dependencies haven’t changed. By default, gitlab-ci-local
stores the cache of the artifacts at .gitlab-ci-local/artifacts/<job_name>
. This is quite a convenient place to check if you need to debug a job.
Manual Jobs
You can trigger a manual job to run during the execution of another job with --manual <job_name>
. For example:
GitLab Variables
When a pipeline is running on GitLab’s servers, a number of pre-defined environment variables get provided that the pipeline scripts can use. When running them locally, gitlab-ci-local
will do it’s best to provide sensible defaults for these variables. However those dealing with authentication and other URLs will not work, as gitlab-ci-local
cannot work out what these should be. In these cases, you can create a file called .gitlab-ci-local-variables.yml
in the root directory of the repository and manually provide the variables.
CI_REGISTRY
defaults to https://registry-1.docker.io/v2/
.
CI_PROJECT_DIR
will be set to /gcl-builds
, which should be where the root directory of the repository resides.
If .gitlab-ci-local-variables.yml
ends up containing sensitive information like personal access tokens, do not commit this file to the repository! Make sure to add it to your .gitignore
file.
Variables In Variables
It doesn’t look like gitlab-ci-local
supports defining variables using other variables. For example, this is works when running on GitLab:
But when this same job is run locally with gitlab-ci-local
, the variable does not get updated, as just seems to set to what ever value it was as if this expression was never run.
Authentication
Normal pipelines that are run on GitLab’s servers get provided with a CI_JOB_TOKEN
which can be used to authenticate when pulling submodules that are other private GitLab repositories, or when pulling/pushing to the GitLab container registry. If you want access when running locally, first create a personal access token through the GitLab web interface (with the necessary permissions). Then add it to your .gitlab-ci-local-variables.yml
file as shown:
Image Registry
If you access the repos image registry (or another GitLab repo’s image registry) you will need to set both CI_JOB_TOKEN
and CI_REGISTRY_IMAGE
in .gitlab-ci-local-variables.yml
.
CI_REGISTRY_IMAGE
should be in the format registry.gitlab.com/<namespace>/<project>
, e.g. registry.gitlab.com/my-group/my-project
. You can copy the registry URL from the GitLab web interface by going to the image registry and copying any one image URL to the clipboard, and then removing the :tag
from the end of the URL.
Watch Out For Untracked Files
GCL will not sync local files that are not tracked by Git. So if you are playing around and add a completely new file, you might run into a “file not found” error when running your pipeline. To fix this, all you need to do is run git add ...
to stage the file in git (it doesn’t need to be committed)2.
The file does not need to be continuously re-added to the git staging area when changes are made, as long as the file has been staged (or committed) at least once.
Caching
gitlab-ci-local
does not support the GitLab caching feature. gitlab-ci.yml
statements like:
will not be cached when running the job locally with gitlab-ci-local
, and so expect things to run slower in this situation.
GitLab Runners
GitLab runners are the machines/applications that run your CI pipelines. GitLab runners can be configured and run on GitLab’s servers (GitLab-hosted runners) or self-hosted on your own servers.
You use tags (GitLab tags, not Git tags) to specify what runner should run a job. GitLab-hosted runners will by default (an untagged job) use the small
Linux x86-64 runner3.
GitLab-hosted runners support Linux, Windows and MacOS. As of November 2024, the Windows and MacOS runners are in beta3.
To use a Windows runner, you would use the saas-windows-medium-amd64
tag as follows:
Footnotes
-
GitLab (2015, Jul 3). Our new logo [blog post]. Retrieved 2024-10-14, from https://about.gitlab.com/blog/2015/07/03/our-new-logo/. ↩
-
GitHub. firecow/gitlab-ci-local [repo README]. Retrieved 2024-10-02, from https://github.com/firecow/gitlab-ci-local. ↩ ↩2
-
GitLab. GitLab-hosted runners [docs]. Retrieved 2024-11-11, from https://docs.gitlab.com/ee/ci/runners/index.html. ↩ ↩2