.gitea/workflows/docker-builder.yml aktualisiert
All checks were successful
Docker Build Dynamic / Build amd64 & arm64 (push) Successful in 26s

add dynamic image-name from git-repo
This commit is contained in:
2026-02-05 12:54:10 +00:00
parent 778251052b
commit 6e55c01144

View File

@@ -1,4 +1,4 @@
name: Docker Build Split name: Docker Build Dynamic
on: on:
push: push:
@@ -7,47 +7,49 @@ on:
workflow_dispatch: workflow_dispatch:
env: env:
# Das Ziel-Repo (Das saubere Repo) REGISTRY_HOST: git.pi-farm.de
IMAGE_NAME: git.pi-farm.de/pi-farm/docker-baseimage-alpine # Nutzt das aktuelle Repo (z.B. pi-farm/docker-baseimage-alpine)
# Das Cache-Repo (Für die Zwischen-Images) - MUSS IN GITEA EXISTIEREN IMAGE_BASE: ${{ gitea.repository }}
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
runs-on: buildx-multiarch runs-on: buildx-multiarch
steps: steps:
- name: Checkout repository - name: Checkout repository
uses: actions/checkout@v4 uses: actions/checkout@v4
- name: Set image tag from branch - name: Set dynamic variables
run: | run: |
# Branch Name als Version
VERSION=$(git rev-parse --abbrev-ref HEAD) VERSION=$(git rev-parse --abbrev-ref HEAD)
if [ -z "$VERSION" ]; then
echo "ERROR: could not determine branch name" # Zusammenbau der vollen Pfade
exit 1 # Ziel: git.pi-farm.de/owner/repo
fi FULL_IMAGE_NAME="${{ env.REGISTRY_HOST }}/${{ env.IMAGE_BASE }}"
# Ziel: git.pi-farm.de/owner/repo-cache
CACHE_IMAGE_NAME="${{ env.REGISTRY_HOST }}/${{ env.IMAGE_BASE }}-cache"
echo "VERSION=$VERSION" >> $GITEA_ENV echo "VERSION=$VERSION" >> $GITEA_ENV
echo "IMAGE_NAME=$FULL_IMAGE_NAME" >> $GITEA_ENV
echo "CACHE_IMAGE_NAME=$CACHE_IMAGE_NAME" >> $GITEA_ENV
echo "BUILD_DATE=$(date -u +%Y-%m-%dT%H:%M:%SZ)" >> $GITEA_ENV echo "BUILD_DATE=$(date -u +%Y-%m-%dT%H:%M:%SZ)" >> $GITEA_ENV
- name: Login to registry - name: Login to registry
run: | run: |
echo "${{ secrets.REGISTRY_PASSWORD }}" | docker login \ echo "${{ secrets.REGISTRY_PASSWORD }}" | docker login \
git.pi-farm.de \ ${{ env.REGISTRY_HOST }} \
-u ${{ secrets.REGISTRY_USER }} \ -u ${{ secrets.REGISTRY_USER }} \
--password-stdin --password-stdin
- name: Setup buildx - name: Setup buildx
run: | run: |
docker buildx rm multiarch || true docker buildx rm multiarch || true
docker buildx create \ docker buildx create --name multiarch --driver docker-container --use
--name multiarch \
--driver docker-container \
--use
docker buildx inspect --bootstrap docker buildx inspect --bootstrap
# SCHRITT 1: AMD64 bauen -> In das CACHE Repo pushen
- name: Build & push amd64 (Cache) - name: Build & push amd64 (Cache)
run: | run: |
docker buildx build \ docker buildx build \
@@ -56,10 +58,8 @@ jobs:
--build-arg BUILD_DATE=${BUILD_DATE} \ --build-arg BUILD_DATE=${BUILD_DATE} \
--build-arg VERSION=${VERSION} \ --build-arg VERSION=${VERSION} \
-t ${CACHE_IMAGE_NAME}:${VERSION}-amd64 \ -t ${CACHE_IMAGE_NAME}:${VERSION}-amd64 \
--push \ --push .
.
# SCHRITT 2: ARM64 bauen -> In das CACHE Repo pushen
- name: Build & push arm64 (Cache) - name: Build & push arm64 (Cache)
run: | run: |
docker buildx build \ docker buildx build \
@@ -68,12 +68,8 @@ jobs:
--build-arg BUILD_DATE=${BUILD_DATE} \ --build-arg BUILD_DATE=${BUILD_DATE} \
--build-arg VERSION=${VERSION} \ --build-arg VERSION=${VERSION} \
-t ${CACHE_IMAGE_NAME}:${VERSION}-arm64 \ -t ${CACHE_IMAGE_NAME}:${VERSION}-arm64 \
--push \ --push .
.
# 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 - name: Create and push manifest to Prod
run: | run: |
docker buildx imagetools create \ docker buildx imagetools create \