chore: clean up the dind rootless dockerfile so it aligns with the other runners (#1926)
* chore: align dockerfile with other runners * chore: superfluous comments * feat: make docker compose download arch aware * chore: stuff * chore: align runner tool cache set-up * fix: copy and paste error * feat: add container hooks * feat: add rootless into makefile * feat: support all architectures and fix compose * fix: export SKIP_IPTABLES correctly Co-authored-by: toast-gear <toast-gear@users.noreply.github.com>
This commit is contained in:
		
							parent
							
								
									ae86b1a011
								
							
						
					
					
						commit
						9ba4b6b96a
					
				|  | @ -2,6 +2,7 @@ DOCKER_USER ?= summerwind | ||||||
| DOCKER ?= docker | DOCKER ?= docker | ||||||
| NAME ?= ${DOCKER_USER}/actions-runner | NAME ?= ${DOCKER_USER}/actions-runner | ||||||
| DIND_RUNNER_NAME ?= ${DOCKER_USER}/actions-runner-dind | DIND_RUNNER_NAME ?= ${DOCKER_USER}/actions-runner-dind | ||||||
|  | DIND_ROOTLESS_RUNNER_NAME ?= ${DOCKER_USER}/actions-runner-dind-rootless | ||||||
| TAG ?= latest | TAG ?= latest | ||||||
| TARGETPLATFORM ?= $(shell arch) | TARGETPLATFORM ?= $(shell arch) | ||||||
| 
 | 
 | ||||||
|  | @ -40,10 +41,18 @@ docker-build-ubuntu: | ||||||
| 	  --build-arg DOCKER_VERSION=${DOCKER_VERSION} \
 | 	  --build-arg DOCKER_VERSION=${DOCKER_VERSION} \
 | ||||||
| 	  -f actions-runner-dind.dockerfile \
 | 	  -f actions-runner-dind.dockerfile \
 | ||||||
| 	  -t ${DIND_RUNNER_NAME}:${TAG} . | 	  -t ${DIND_RUNNER_NAME}:${TAG} . | ||||||
|  | 	${DOCKER} build \
 | ||||||
|  | 	  --build-arg TARGETPLATFORM=${TARGETPLATFORM} \
 | ||||||
|  | 	  --build-arg RUNNER_VERSION=${RUNNER_VERSION} \
 | ||||||
|  | 	  --build-arg RUNNER_CONTAINER_HOOKS_VERSION=${RUNNER_CONTAINER_HOOKS_VERSION} \
 | ||||||
|  | 	  --build-arg DOCKER_VERSION=${DOCKER_VERSION} \
 | ||||||
|  | 	  -f actions-runner-dind-rootless.dockerfile \
 | ||||||
|  | 	  -t ${DIND_ROOTLESS_RUNNER_NAME}:${TAG} . | ||||||
| 
 | 
 | ||||||
| docker-push-ubuntu: | docker-push-ubuntu: | ||||||
| 	${DOCKER} push ${NAME}:${TAG} | 	${DOCKER} push ${NAME}:${TAG} | ||||||
| 	${DOCKER} push ${DIND_RUNNER_NAME}:${TAG} | 	${DOCKER} push ${DIND_RUNNER_NAME}:${TAG} | ||||||
|  | 	${DOCKER} push ${DIND_ROOTLESS_RUNNER_NAME}:${TAG} | ||||||
| 
 | 
 | ||||||
| docker-buildx-ubuntu: | docker-buildx-ubuntu: | ||||||
| 	export DOCKER_CLI_EXPERIMENTAL=enabled ;\
 | 	export DOCKER_CLI_EXPERIMENTAL=enabled ;\
 | ||||||
|  |  | ||||||
|  | @ -1,24 +1,19 @@ | ||||||
| FROM ubuntu:20.04 | FROM ubuntu:20.04 | ||||||
| 
 | 
 | ||||||
| # Target architecture | ARG TARGETPLATFORM | ||||||
| ARG TARGETPLATFORM=linux/amd64 |  | ||||||
| 
 |  | ||||||
| # GitHub runner arguments |  | ||||||
| ARG RUNNER_VERSION=2.299.1 | ARG RUNNER_VERSION=2.299.1 | ||||||
| 
 | ARG RUNNER_CONTAINER_HOOKS_VERSION=0.1.2 | ||||||
| # Docker and Docker Compose arguments | # Docker and Docker Compose arguments | ||||||
| ENV CHANNEL=stable | ENV CHANNEL=stable | ||||||
| ARG COMPOSE_VERSION=v2.6.0 | ARG DOCKER_COMPOSE_VERSION=v2.6.0 | ||||||
| 
 |  | ||||||
| # Dumb-init version |  | ||||||
| ARG DUMB_INIT_VERSION=1.2.5 | ARG DUMB_INIT_VERSION=1.2.5 | ||||||
| 
 | 
 | ||||||
| # Other arguments | # Other arguments | ||||||
| ARG DEBUG=false | ARG DEBUG=false | ||||||
| 
 | 
 | ||||||
| # Set environment variables needed at build | RUN test -n "$TARGETPLATFORM" || (echo "TARGETPLATFORM must be set" && false) | ||||||
| ENV DEBIAN_FRONTEND=noninteractive |  | ||||||
| 
 | 
 | ||||||
|  | ENV DEBIAN_FRONTEND=noninteractive | ||||||
| RUN apt update -y \ | RUN apt update -y \ | ||||||
|     && apt-get install -y software-properties-common \ |     && apt-get install -y software-properties-common \ | ||||||
|     && add-apt-repository -y ppa:git-core/ppa \ |     && add-apt-repository -y ppa:git-core/ppa \ | ||||||
|  | @ -63,57 +58,63 @@ RUN apt update -y \ | ||||||
| # Runner user | # Runner user | ||||||
| RUN adduser --disabled-password --gecos "" --uid 1000 runner | RUN adduser --disabled-password --gecos "" --uid 1000 runner | ||||||
| 
 | 
 | ||||||
| RUN test -n "$TARGETPLATFORM" || (echo "TARGETPLATFORM must be set" && false) | ENV HOME=/home/runner | ||||||
| 
 | 
 | ||||||
| # Setup subuid and subgid so that "--userns-remap=default" works | # Set-up subuid and subgid so that "--userns-remap=default" works | ||||||
| RUN set -eux; \ | RUN set -eux; \ | ||||||
|     addgroup --system dockremap; \ |     addgroup --system dockremap; \ | ||||||
|     adduser --system --ingroup dockremap dockremap; \ |     adduser --system --ingroup dockremap dockremap; \ | ||||||
|     echo 'dockremap:165536:65536' >> /etc/subuid; \ |     echo 'dockremap:165536:65536' >> /etc/subuid; \ | ||||||
|     echo 'dockremap:165536:65536' >> /etc/subgid |     echo 'dockremap:165536:65536' >> /etc/subgid | ||||||
| 
 | 
 | ||||||
| ENV RUNNER_ASSETS_DIR=/runnertmp |  | ||||||
| 
 |  | ||||||
| # Runner download supports amd64 as x64 |  | ||||||
| RUN ARCH=$(echo ${TARGETPLATFORM} | cut -d / -f2) \ |  | ||||||
|     && export ARCH \ |  | ||||||
|     && if [ "$ARCH" = "amd64" ]; then export ARCH=x64 ; fi \ |  | ||||||
|     && mkdir -p "$RUNNER_ASSETS_DIR" \ |  | ||||||
|     && cd "$RUNNER_ASSETS_DIR" \ |  | ||||||
|     && curl -L -o runner.tar.gz https://github.com/actions/runner/releases/download/v${RUNNER_VERSION}/actions-runner-linux-${ARCH}-${RUNNER_VERSION}.tar.gz \ |  | ||||||
|     && tar xzf ./runner.tar.gz \ |  | ||||||
|     && rm runner.tar.gz \ |  | ||||||
|     && ./bin/installdependencies.sh \ |  | ||||||
|     && apt-get install -y libyaml-dev \ |  | ||||||
|     && rm -rf /var/lib/apt/lists/* |  | ||||||
| 
 |  | ||||||
| RUN echo AGENT_TOOLSDIRECTORY=/opt/hostedtoolcache > /runner.env \ |  | ||||||
|     && mkdir /opt/hostedtoolcache \ |  | ||||||
|     && chgrp runner /opt/hostedtoolcache \ |  | ||||||
|     && chmod g+rwx /opt/hostedtoolcache |  | ||||||
| 
 |  | ||||||
| # Configure hooks folder structure. |  | ||||||
| COPY hooks /etc/arc/hooks/ |  | ||||||
| 
 |  | ||||||
| # arch command on OS X reports "i386" for Intel CPUs regardless of bitness |  | ||||||
| RUN export ARCH=$(echo ${TARGETPLATFORM} | cut -d / -f2) \ | RUN export ARCH=$(echo ${TARGETPLATFORM} | cut -d / -f2) \ | ||||||
|     && if [ "$ARCH" = "arm64" ]; then export ARCH=aarch64 ; fi \ |     && if [ "$ARCH" = "arm64" ]; then export ARCH=aarch64 ; fi \ | ||||||
|     && if [ "$ARCH" = "amd64" ] || [ "$ARCH" = "i386" ]; then export ARCH=x86_64 ; fi \ |     && if [ "$ARCH" = "amd64" ] || [ "$ARCH" = "i386" ]; then export ARCH=x86_64 ; fi \ | ||||||
|     && curl -f -L -o /usr/local/bin/dumb-init https://github.com/Yelp/dumb-init/releases/download/v${DUMB_INIT_VERSION}/dumb-init_${DUMB_INIT_VERSION}_${ARCH} \ |     && curl -fLo /usr/bin/dumb-init https://github.com/Yelp/dumb-init/releases/download/v${DUMB_INIT_VERSION}/dumb-init_${DUMB_INIT_VERSION}_${ARCH} \ | ||||||
|     && chmod +x /usr/local/bin/dumb-init |     && chmod +x /usr/bin/dumb-init | ||||||
| 
 | 
 | ||||||
|  | ENV RUNNER_ASSETS_DIR=/runnertmp | ||||||
|  | RUN export ARCH=$(echo ${TARGETPLATFORM} | cut -d / -f2) \ | ||||||
|  |     && if [ "$ARCH" = "amd64" ] || [ "$ARCH" = "x86_64" ] || [ "$ARCH" = "i386" ]; then export ARCH=x64 ; fi \ | ||||||
|  |     && mkdir -p "$RUNNER_ASSETS_DIR" \ | ||||||
|  |     && cd "$RUNNER_ASSETS_DIR" \ | ||||||
|  |     && curl -fLo runner.tar.gz https://github.com/actions/runner/releases/download/v${RUNNER_VERSION}/actions-runner-linux-${ARCH}-${RUNNER_VERSION}.tar.gz \ | ||||||
|  |     && tar xzf ./runner.tar.gz \ | ||||||
|  |     && rm runner.tar.gz \ | ||||||
|  |     && ./bin/installdependencies.sh \ | ||||||
|  |     && mv ./externals ./externalstmp \ | ||||||
|  |     # libyaml-dev is required for ruby/setup-ruby action. | ||||||
|  |     # It is installed after installdependencies.sh and before removing /var/lib/apt/lists | ||||||
|  |     # to avoid rerunning apt-update on its own. | ||||||
|  |     && apt-get install -y libyaml-dev \ | ||||||
|  |     && rm -rf /var/lib/apt/lists/* | ||||||
|  | 
 | ||||||
|  | ENV RUNNER_TOOL_CACHE=/opt/hostedtoolcache | ||||||
|  | RUN mkdir /opt/hostedtoolcache \ | ||||||
|  |     && chgrp runner /opt/hostedtoolcache \ | ||||||
|  |     && chmod g+rwx /opt/hostedtoolcache | ||||||
|  | 
 | ||||||
|  | RUN cd "$RUNNER_ASSETS_DIR" \ | ||||||
|  |     && curl -fLo runner-container-hooks.zip https://github.com/actions/runner-container-hooks/releases/download/v${RUNNER_CONTAINER_HOOKS_VERSION}/actions-runner-hooks-k8s-${RUNNER_CONTAINER_HOOKS_VERSION}.zip \ | ||||||
|  |     && unzip ./runner-container-hooks.zip -d ./k8s \ | ||||||
|  |     && rm -f runner-container-hooks.zip | ||||||
|  | 
 | ||||||
|  | # Make the rootless runner directory executable | ||||||
|  | RUN mkdir /run/user/1000 \ | ||||||
|  |     && chown runner:runner /run/user/1000 \ | ||||||
|  |     && chmod a+x /run/user/1000 | ||||||
|  | 
 | ||||||
|  | # We place the scripts in `/usr/bin` so that users who extend this image can | ||||||
|  | # override them with scripts of the same name placed in `/usr/local/bin`. | ||||||
| COPY entrypoint-dind-rootless.sh startup.sh logger.sh graceful-stop.sh update-status /usr/bin/ | COPY entrypoint-dind-rootless.sh startup.sh logger.sh graceful-stop.sh update-status /usr/bin/ | ||||||
| 
 |  | ||||||
| RUN chmod +x /usr/bin/entrypoint-dind-rootless.sh /usr/bin/startup.sh | RUN chmod +x /usr/bin/entrypoint-dind-rootless.sh /usr/bin/startup.sh | ||||||
| 
 | 
 | ||||||
| # Copy the docker shim which propagates the docker MTU to underlying networks | # Copy the docker shim which propagates the docker MTU to underlying networks | ||||||
| # to replace the docker binary in the PATH. | # to replace the docker binary in the PATH. | ||||||
| COPY docker-shim.sh /usr/local/bin/docker | COPY docker-shim.sh /usr/local/bin/docker | ||||||
| 
 | 
 | ||||||
| # Make the rootless runner directory executable | # Configure hooks folder structure. | ||||||
| RUN mkdir /run/user/1000 \ | COPY hooks /etc/arc/hooks/ | ||||||
|     && chown runner:runner /run/user/1000 \ |  | ||||||
|     && chmod a+x /run/user/1000 |  | ||||||
| 
 | 
 | ||||||
| # Add the Python "User Script Directory" to the PATH | # Add the Python "User Script Directory" to the PATH | ||||||
| ENV PATH="${PATH}:${HOME}/.local/bin:/home/runner/bin" | ENV PATH="${PATH}:${HOME}/.local/bin:/home/runner/bin" | ||||||
|  | @ -126,19 +127,18 @@ RUN echo "PATH=${PATH}" > /etc/environment \ | ||||||
|     && echo "DOCKER_HOST=${DOCKER_HOST}" >> /etc/environment \ |     && echo "DOCKER_HOST=${DOCKER_HOST}" >> /etc/environment \ | ||||||
|     && echo "XDG_RUNTIME_DIR=${XDG_RUNTIME_DIR}" >> /etc/environment |     && echo "XDG_RUNTIME_DIR=${XDG_RUNTIME_DIR}" >> /etc/environment | ||||||
| 
 | 
 | ||||||
| ENV HOME=/home/runner |  | ||||||
| 
 |  | ||||||
| # No group definition, as that makes it harder to run docker. | # No group definition, as that makes it harder to run docker. | ||||||
| USER runner | USER runner | ||||||
| 
 | 
 | ||||||
| # Docker installation |  | ||||||
| ENV SKIP_IPTABLES=1 |  | ||||||
| # This will install docker under $HOME/bin according to the content of the script | # This will install docker under $HOME/bin according to the content of the script | ||||||
| RUN curl -fsSL https://get.docker.com/rootless | sh | RUN export SKIP_IPTABLES=1 \ | ||||||
|  |     && curl -fsSL https://get.docker.com/rootless | sh | ||||||
| 
 | 
 | ||||||
| # Docker-compose installation | RUN export ARCH=$(echo ${TARGETPLATFORM} | cut -d / -f2) \ | ||||||
| RUN curl -L "https://github.com/docker/compose/releases/download/${COMPOSE_VERSION}/docker-compose-Linux-x86_64" -o /home/runner/bin/docker-compose ; \ |     && if [ "$ARCH" = "arm64" ]; then export ARCH=aarch64 ; fi \ | ||||||
|     chmod +x /home/runner/bin/docker-compose |     && if [ "$ARCH" = "amd64" ] || [ "$ARCH" = "i386" ]; then export ARCH=x86_64 ; fi \ | ||||||
|  |     && curl -fLo /home/runner/bin/docker-compose https://github.com/docker/compose/releases/download/${DOCKER_COMPOSE_VERSION}/docker-compose-linux-${ARCH} \ | ||||||
|  |     && chmod +x /home/runner/bin/docker-compose | ||||||
| 
 | 
 | ||||||
| ENTRYPOINT ["/bin/bash", "-c"] | ENTRYPOINT ["/bin/bash", "-c"] | ||||||
| CMD ["entrypoint-dind-rootless.sh"] | CMD ["entrypoint-dind-rootless.sh"] | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue