How to setup GitHub hosted runner with a simple cloud-init script
Edit: RunsOn is now available as a modern way to setup self-hosted GitHub Actions runners!
While waiting for the RunsOn ephemeral self-hosted runners service, here is a short bash script, that can also be used as cloud-init script for launching GitHub hosted runners non-interactively:
#!/bin/bash -ex
set -o pipefail
RUNNER_ORG=YOUR_ORGRUNNER_TOKEN=YOUR_TOKENRUNNER_LABELS=self-hosted,x64,docker# update this to the latest versionRUNNER_VERSION=2.311.0
# Install docker, then additional packages and stuff:apt update -qqapt install -y ruby awsclicurl https://nodejs.org/dist/v20.9.0/node-v20.9.0-linux-x64.tar.xz | tar -xJf - --strip=1 -C /usr/local/
curl https://get.docker.com | sh
cat > /etc/cron.daily/docker-prune <<EOFdocker image prune -a --filter="until=96h" --forcedocker volume prune --forceEOFchmod a+x /etc/cron.daily/docker-prune
# Create dedicated useruseradd -m -d /home/runner -s /bin/bash runnerusermod -G docker runner
# Download and install runner scriptcd /home/runnermkdir -p actions-runnercd actions-runnercurl -o actions-runner-linux-x64-$RUNNER_VERSION.tar.gz -L https://github.com/actions/runner/releases/download/v$RUNNER_VERSION/actions-runner-linux-x64-$RUNNER_VERSION.tar.gztar xzf ./actions-runner-linux-x64-$RUNNER_VERSION.tar.gz
# Configure runnersu - runner -c "/home/runner/actions-runner/config.sh --url https://github.com/$RUNNER_ORG --token $RUNNER_TOKEN --labels $RUNNER_LABELS --unattended"
# Setup systemd scriptscd /home/runner/actions-runner/./svc.sh install runner./svc.sh start./svc.sh status
You should be good to go!
Note that those runners won’t be ephemeral, so usual caveats apply regarding security of those runners.