This problem can be solved by running the github actions runner as root, which somewhat reduces security.
A better solution is using rootless docker:
- Remove docker from your system if you have previously installed it through Ubuntu's default repositories.
- install docker from Docker's repositories as directed here (I also recommend
enabling cgroupsV2, as described here) & reboot. This will give you the script in /usr/bin needed to setup rootless docker in the next step.
- setup rootless docker as described here.
- don't forget to run the following, so docker remains running after you logout (as described in the guide)
systemctl --user enable docker
systemctl --user start docker
sudo loginctl enable-linger $(whoami)
Also make sure to create the rootless context as described on that same page. This will make your own docker commands and the github actions runner automatically use rootless docker.
install the self hosted runner: https://docs.github.com/en/actions/hosting-your-own-runners/adding-self-hosted-runners (skip if already installed)
Add the DOCKER_HOST
env var to the .env file in the runner directory. The file might already be created by default. The line you add should look as follows (change the 1000 if your UID is not 1000):
DOCKER_HOST=unix:///run/user/1000/docker.sock
- re(start) the actions runner. This can by done by restarting its systemd service. Your runner should now work with rootless docker
If you're having issues with the new docker build github action using buildx, also see How to solve error with rootless docker in github actions self hosted runner: write /proc/sys/net/ipv4/ping_group_range: invalid argument: unknown