diff --git a/.gitea/workflows/docker-builder.yml b/.gitea/workflows/docker-builder.yml index 1643f21..035f82f 100644 --- a/.gitea/workflows/docker-builder.yml +++ b/.gitea/workflows/docker-builder.yml @@ -1,4 +1,4 @@ -name: Docker Build +name: Docker Build Split on: push: @@ -6,6 +6,12 @@ on: - 3.23 workflow_dispatch: +env: + # Das Ziel-Repo (Das saubere Repo) + IMAGE_NAME: git.pi-farm.de/pi-farm/docker-baseimage-alpine + # Das Cache-Repo (Für die Zwischen-Images) - MUSS IN GITEA EXISTIEREN + CACHE_IMAGE_NAME: git.pi-farm.de/pi-farm/docker-baseimage-alpine-cache + jobs: build: name: Build amd64 & arm64 separately @@ -32,8 +38,6 @@ jobs: -u ${{ secrets.REGISTRY_USER }} \ --password-stdin - # Buildx Setup ist weiterhin notwendig für Caching und Performance, - # auch wenn wir nicht mehr das Multi-Platform-Feature direkt im Build nutzen. - name: Setup buildx run: | docker buildx rm multiarch || true @@ -43,38 +47,36 @@ jobs: --use docker buildx inspect --bootstrap - # SCHRITT 1: AMD64 bauen und mit Suffix -amd64 pushen - # Nutzt 'Dockerfile' - - name: Build & push amd64 + # SCHRITT 1: AMD64 bauen -> In das CACHE Repo pushen + - name: Build & push amd64 (Cache) run: | docker buildx build \ --platform linux/amd64 \ -f Dockerfile \ --build-arg BUILD_DATE=${BUILD_DATE} \ --build-arg VERSION=${VERSION} \ - -t git.pi-farm.de/pi-farm/docker-baseimage-alpine:${VERSION}-amd64 \ + -t ${CACHE_IMAGE_NAME}:${VERSION}-amd64 \ --push \ . - # SCHRITT 2: ARM64 bauen und mit Suffix -arm64 pushen - # Nutzt 'Dockerfile.aarch64' - - name: Build & push arm64 + # SCHRITT 2: ARM64 bauen -> In das CACHE Repo pushen + - name: Build & push arm64 (Cache) run: | docker buildx build \ --platform linux/arm64 \ -f Dockerfile.aarch64 \ --build-arg BUILD_DATE=${BUILD_DATE} \ --build-arg VERSION=${VERSION} \ - -t git.pi-farm.de/pi-farm/docker-baseimage-alpine:${VERSION}-arm64 \ + -t ${CACHE_IMAGE_NAME}:${VERSION}-arm64 \ --push \ . - # SCHRITT 3: Manifest erstellen und pushen - # Klebt die beiden Images (amd64 + arm64) zusammen zum finalen Tag - - name: Create and push manifest + # SCHRITT 3: Manifest erstellen -> In das PROD Repo pushen + # Hier geschieht die Magie: Wir nehmen die Quellen aus dem Cache-Repo + # und erstellen das Manifest im Prod-Repo. + - name: Create and push manifest to Prod run: | - # Manifest erstellen docker buildx imagetools create \ - -t git.pi-farm.de/pi-farm/docker-baseimage-alpine:${VERSION} \ - git.pi-farm.de/pi-farm/docker-baseimage-alpine:${VERSION}-amd64 \ - git.pi-farm.de/pi-farm/docker-baseimage-alpine:${VERSION}-arm64 \ No newline at end of file + -t ${IMAGE_NAME}:${VERSION} \ + ${CACHE_IMAGE_NAME}:${VERSION}-amd64 \ + ${CACHE_IMAGE_NAME}:${VERSION}-arm64 \ No newline at end of file