fix(gitea-runner): use Docker-in-Docker sidecar

K3S uses containerd, not Docker. Use DinD sidecar container
to provide Docker daemon for the runner.

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
2026-01-10 20:40:29 +09:00
parent fa63d0f86a
commit 625c9c2367

View File

@@ -16,30 +16,60 @@ spec:
app: gitea-runner app: gitea-runner
spec: spec:
containers: containers:
# Docker-in-Docker sidecar
- name: dind
image: docker:dind
securityContext:
privileged: true
env:
- name: DOCKER_TLS_CERTDIR
value: ""
volumeMounts:
- name: docker-graph
mountPath: /var/lib/docker
resources:
requests:
cpu: 100m
memory: 512Mi
limits:
memory: 2Gi
# Gitea Actions Runner
- name: runner - name: runner
image: gitea/act_runner:latest image: gitea/act_runner:latest
command: command:
- sh - sh
- -c - -c
- | - |
# Wait for Docker to be ready
echo "Waiting for Docker daemon..."
while ! docker info > /dev/null 2>&1; do
sleep 2
done
echo "Docker is ready!"
# Wait for Gitea to be ready
while ! wget -q --spider http://gitea-http.gitea.svc:3000/api/v1/version; do while ! wget -q --spider http://gitea-http.gitea.svc:3000/api/v1/version; do
echo "Waiting for Gitea to be ready..." echo "Waiting for Gitea to be ready..."
sleep 5 sleep 5
done done
act_runner register --no-interactive \ echo "Gitea is ready!"
--instance https://github0213.com \
--token $(cat /secrets/token) \ # Register runner if not already registered
--name k3s-runner \ if [ ! -f /data/.runner ]; then
--labels k3s-home:docker://node:20-alpine,ubuntu-latest:docker://ubuntu:latest,arm64:host act_runner register --no-interactive \
--instance https://github0213.com \
--token $(cat /secrets/token) \
--name k3s-runner \
--labels k3s-home:docker://node:20-alpine,ubuntu-latest:docker://ubuntu:latest,arm64:host
fi
act_runner daemon act_runner daemon
env: env:
- name: GITEA_INSTANCE_URL - name: GITEA_INSTANCE_URL
value: "https://github0213.com" value: "https://github0213.com"
- name: DOCKER_HOST - name: DOCKER_HOST
value: "unix:///var/run/docker.sock" value: "tcp://localhost:2375"
volumeMounts: volumeMounts:
- name: docker-sock
mountPath: /var/run/docker.sock
- name: runner-data - name: runner-data
mountPath: /data mountPath: /data
- name: runner-secret - name: runner-secret
@@ -51,13 +81,9 @@ spec:
memory: 256Mi memory: 256Mi
limits: limits:
memory: 1Gi memory: 1Gi
securityContext:
privileged: true
volumes: volumes:
- name: docker-sock - name: docker-graph
hostPath: emptyDir: {}
path: /var/run/docker.sock
type: Socket
- name: runner-data - name: runner-data
emptyDir: {} emptyDir: {}
- name: runner-secret - name: runner-secret
@@ -69,4 +95,3 @@ spec:
- key: node-role.kubernetes.io/control-plane - key: node-role.kubernetes.io/control-plane
operator: Exists operator: Exists
effect: NoSchedule effect: NoSchedule
restartPolicy: Always