.gitea/workflows/docker-builder.yml aktualisiert
All checks were successful
Docker Build Split / Build amd64 & arm64 separately (push) Successful in 26s
All checks were successful
Docker Build Split / Build amd64 & arm64 separately (push) Successful in 26s
This commit is contained in:
@@ -1,4 +1,4 @@
|
|||||||
name: Docker Build
|
name: Docker Build Split
|
||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
@@ -6,6 +6,12 @@ on:
|
|||||||
- 3.23
|
- 3.23
|
||||||
workflow_dispatch:
|
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:
|
jobs:
|
||||||
build:
|
build:
|
||||||
name: Build amd64 & arm64 separately
|
name: Build amd64 & arm64 separately
|
||||||
@@ -32,8 +38,6 @@ jobs:
|
|||||||
-u ${{ secrets.REGISTRY_USER }} \
|
-u ${{ secrets.REGISTRY_USER }} \
|
||||||
--password-stdin
|
--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
|
- name: Setup buildx
|
||||||
run: |
|
run: |
|
||||||
docker buildx rm multiarch || true
|
docker buildx rm multiarch || true
|
||||||
@@ -43,38 +47,36 @@ jobs:
|
|||||||
--use
|
--use
|
||||||
docker buildx inspect --bootstrap
|
docker buildx inspect --bootstrap
|
||||||
|
|
||||||
# SCHRITT 1: AMD64 bauen und mit Suffix -amd64 pushen
|
# SCHRITT 1: AMD64 bauen -> In das CACHE Repo pushen
|
||||||
# Nutzt 'Dockerfile'
|
- name: Build & push amd64 (Cache)
|
||||||
- name: Build & push amd64
|
|
||||||
run: |
|
run: |
|
||||||
docker buildx build \
|
docker buildx build \
|
||||||
--platform linux/amd64 \
|
--platform linux/amd64 \
|
||||||
-f Dockerfile \
|
-f Dockerfile \
|
||||||
--build-arg BUILD_DATE=${BUILD_DATE} \
|
--build-arg BUILD_DATE=${BUILD_DATE} \
|
||||||
--build-arg VERSION=${VERSION} \
|
--build-arg VERSION=${VERSION} \
|
||||||
-t git.pi-farm.de/pi-farm/docker-baseimage-alpine:${VERSION}-amd64 \
|
-t ${CACHE_IMAGE_NAME}:${VERSION}-amd64 \
|
||||||
--push \
|
--push \
|
||||||
.
|
.
|
||||||
|
|
||||||
# SCHRITT 2: ARM64 bauen und mit Suffix -arm64 pushen
|
# SCHRITT 2: ARM64 bauen -> In das CACHE Repo pushen
|
||||||
# Nutzt 'Dockerfile.aarch64'
|
- name: Build & push arm64 (Cache)
|
||||||
- name: Build & push arm64
|
|
||||||
run: |
|
run: |
|
||||||
docker buildx build \
|
docker buildx build \
|
||||||
--platform linux/arm64 \
|
--platform linux/arm64 \
|
||||||
-f Dockerfile.aarch64 \
|
-f Dockerfile.aarch64 \
|
||||||
--build-arg BUILD_DATE=${BUILD_DATE} \
|
--build-arg BUILD_DATE=${BUILD_DATE} \
|
||||||
--build-arg VERSION=${VERSION} \
|
--build-arg VERSION=${VERSION} \
|
||||||
-t git.pi-farm.de/pi-farm/docker-baseimage-alpine:${VERSION}-arm64 \
|
-t ${CACHE_IMAGE_NAME}:${VERSION}-arm64 \
|
||||||
--push \
|
--push \
|
||||||
.
|
.
|
||||||
|
|
||||||
# SCHRITT 3: Manifest erstellen und pushen
|
# SCHRITT 3: Manifest erstellen -> In das PROD Repo pushen
|
||||||
# Klebt die beiden Images (amd64 + arm64) zusammen zum finalen Tag
|
# Hier geschieht die Magie: Wir nehmen die Quellen aus dem Cache-Repo
|
||||||
- name: Create and push manifest
|
# und erstellen das Manifest im Prod-Repo.
|
||||||
|
- name: Create and push manifest to Prod
|
||||||
run: |
|
run: |
|
||||||
# Manifest erstellen
|
|
||||||
docker buildx imagetools create \
|
docker buildx imagetools create \
|
||||||
-t git.pi-farm.de/pi-farm/docker-baseimage-alpine:${VERSION} \
|
-t ${IMAGE_NAME}:${VERSION} \
|
||||||
git.pi-farm.de/pi-farm/docker-baseimage-alpine:${VERSION}-amd64 \
|
${CACHE_IMAGE_NAME}:${VERSION}-amd64 \
|
||||||
git.pi-farm.de/pi-farm/docker-baseimage-alpine:${VERSION}-arm64
|
${CACHE_IMAGE_NAME}:${VERSION}-arm64
|
||||||
Reference in New Issue
Block a user