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:
@@ -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
|
|
||||||
|
|||||||
Reference in New Issue
Block a user