Gitlab Pipelines
Gitlab pipeline runners support multiple installation and runtime configurations. This guide will
create a very basic runner using the shell
executor in order to avoid running docker-in-docker.
This guide provides both manual and automated setup instructions, skip to the bottom of the page for
the automation script.
You may find more in-depth information regarding Gitlab Runners at the following links:
Manual
Download and install the Gitlab runner application on your host
# Download the binary for your system
sudo curl -L --output /usr/local/bin/gitlab-runner https://gitlab-runner-downloads.s3.amazonaws.com/latest/binaries/gitlab-runner-linux-amd64
# Give it permission to execute
sudo chmod +x /usr/local/bin/gitlab-runner
# Create a GitLab Runner user
sudo useradd --comment 'GitLab Runner' --create-home gitlab-runner --shell /bin/bash
# Install and run as a service
sudo gitlab-runner install --user=gitlab-runner --working-directory=/home/gitlab-runner
sudo gitlab-runner startLog in to Gitlab and navigate to the repo you want to create a runner for
data:image/s3,"s3://crabby-images/9eb1a/9eb1ab0cd214f19ac08ee1a4db41fca6010fe1e4" alt=""
- From the menu on the left, select
Settings
then chooseCI/CD
from the pop-out list.
data:image/s3,"s3://crabby-images/91669/916697e3cac4471bc27c66863a2579448cc37c17" alt=""
- Find the
Runners
section and click theexpand
button
data:image/s3,"s3://crabby-images/28f6b/28f6b9dd03e3e476015077b52db6f55deeced80a" alt=""
- Select
New Project Runner
data:image/s3,"s3://crabby-images/734a3/734a36b443c7b2dcbaffc00c19db8c4c20460943" alt=""
- Choose
Linux
as the operating system
data:image/s3,"s3://crabby-images/a2be3/a2be3b363d086eb693a8a039bbd51e12c1ab300c" alt=""
- Optionally, check the
Run untagged jobs
box if you would liek your runner to be the default for all jobs.
data:image/s3,"s3://crabby-images/0efa3/0efa3d5ddea0ca37f7c611ece121c76a4bbe03f9" alt=""
- Click the
Create Runner
button at the bottom of the page
data:image/s3,"s3://crabby-images/8c179/8c179c3fd14635b513c95db953daa4d7a1ae8177" alt=""
- Follow the instructions provided to register your runner
data:image/s3,"s3://crabby-images/72504/72504f286886fd93c0dd67cd5b2fa7101979443d" alt=""
Automated
The following script will perform the same actions as described above automatically. This is usefull for those who would prefer ephemeral runners or to use a declarative workflow. You will need to provide your own project access-token to the script as an input value. For mor in-depth information see the following resources:
- Tutorial: Create, register, and run your own project runner
- Tutorial: Automate runner creation and registration
- Runner Executors
- From the main page of your Gitlab repository, select the
Settings
option from the menu on the left.
data:image/s3,"s3://crabby-images/9eb1a/9eb1ab0cd214f19ac08ee1a4db41fca6010fe1e4" alt=""
- Select the
Access Tokens
menu
data:image/s3,"s3://crabby-images/58b56/58b5600c5b7f24b21963a140d1d35dd3b9a49660" alt=""
- Select
Add new token
data:image/s3,"s3://crabby-images/f43f9/f43f9bfee87e43a891232bc3691062a70d5cbb1d" alt=""
- Give the new token a name and expiration date
data:image/s3,"s3://crabby-images/2b259/2b2599148d2dffe9b936f06875824c37c5ed32e0" alt=""
- Set the following role and scopes for the token:
data:image/s3,"s3://crabby-images/a0faf/a0faf47542ebff38eb4578a36597006b87a8ac34" alt=""
- Click the
Create Token
button
data:image/s3,"s3://crabby-images/d220a/d220a62ea55ef9c9cee6d41baa3a94b56b890d79" alt=""
- Save the token string somewhere secure
data:image/s3,"s3://crabby-images/559e0/559e0d7e8ba47e0c3922a1cc9350dc4db9e1e98c" alt=""
Copy and paste the following into your terminal to create the script
/usr/bin/cat << 'EOF' > runner.sh
#!/bin/bash
export DOWNLOAD_URL="https://gitlab-runner-downloads.s3.amazonaws.com/latest/deb/gitlab-runner_amd64.deb"
curl -LJO "${DOWNLOAD_URL}"
sudo dpkg -i gitlab-runner_amd64.deb
export GITLAB_URL=$1
export PROJECT_ID=$2
export GITLAB_TOKEN=$3
RETURN=$(curl --silent --request POST --url "$GITLAB_URL/api/v4/user/runners" \
--data "runner_type=project_type" \
--data "project_id=$PROJECT_ID" \
--data "description=gameci runner" \
--data "tag_list=" \
--header "PRIVATE-TOKEN: $GITLAB_TOKEN")
TOKEN=$(echo $RETURN |jq -r '.token')
sudo gitlab-runner register \
--non-interactive \
--name "gameci-runner" \
--url "$GITLAB_URL" \
--token "$TOKEN" \
--executor "shell" \
--docker-image ubuntu:latest
sudo usermod -aG docker gitlab-runner
EOFRun the script as follows:
bash ./runner.sh <gitlab-url> <project-id> <project-token>