.gitea/workflows/docker-builder.yml aktualisiert
All checks were successful
Docker Build Dynamic / Build amd64 & arm64 (push) Successful in 26s
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:
@@ -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 \
|
||||||
|
|||||||
Reference in New Issue
Block a user