Verbesserung der Docker-Workflow-Konfiguration und Aktualisierung der Image-Referenzen

This commit is contained in:
2025-11-01 18:17:33 +01:00
parent e354d8aabd
commit 26c22f907b
2 changed files with 47 additions and 35 deletions

View File

@@ -7,68 +7,80 @@ on:
workflow_dispatch: workflow_dispatch:
inputs: inputs:
extra_tag: extra_tag:
description: "Optionaler zusätzlicher Tag (z.B. v1.2.3). Wird zusätzlich zu :latest und :<sha> gepusht." description: "Optionaler Zusatz-Tag (z.B. v1.2.3). Kommt zusätzlich zu :latest und :<sha>."
required: false required: false
default: "" default: ""
jobs: jobs:
build-and-push: build-and-push:
runs-on: ubuntu-latest runs-on: ubuntu-latest
env:
REGISTRY: docker.io
DOCKERHUB_USER_LC: ${{ secrets.DOCKERHUB_USERNAME }}
steps: steps:
- name: Checkout repository - name: Checkout
uses: actions/checkout@v4 uses: actions/checkout@v4
with: with:
fetch-depth: 0 fetch-depth: 0
- name: Log in to Docker Hub - name: Get short SHA
id: vars
run: echo "sha=$(git rev-parse --short HEAD)" >> $GITHUB_OUTPUT
- name: Login to Docker Hub
uses: docker/login-action@v3 uses: docker/login-action@v3
with: with:
registry: docker.io registry: docker.io
username: ${{ secrets.DOCKERHUB_USERNAME }} username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }} password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Set up QEMU (for multi-arch) - name: Set up QEMU
uses: docker/setup-qemu-action@v3 uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx - name: Set up Buildx
uses: docker/setup-buildx-action@v3 uses: docker/setup-buildx-action@v3
- name: Get Git commit SHA # -------- BACKEND --------
id: git_sha - name: Build & Push backend (multi-arch)
run: echo "sha=$(git rev-parse --short HEAD)" >> $GITHUB_OUTPUT uses: docker/build-push-action@v6
- name: Define Docker Hub image names
id: image_names
run: |
NS_LC=$(echo "${{ secrets.DOCKERHUB_USERNAME }}" | tr '[:upper:]' '[:lower:]')
echo "backend_image=docker.io/$NS_LC/utools-backend" >> $GITHUB_OUTPUT
echo "frontend_image=docker.io/$NS_LC/utools-frontend" >> $GITHUB_OUTPUT
- name: Build & push multi-arch images via Bake (latest + sha)
uses: docker/bake-action@v5
with: with:
files: | context: ./backend
compose.build.yml file: ./backend/Dockerfile
push: true push: true
set: | platforms: linux/amd64,linux/arm64
*.platform=linux/amd64,linux/arm64 tags: |
backend.tags=${{ steps.image_names.outputs.backend_image }}:latest ${{ env.REGISTRY }}/${{ env.DOCKERHUB_USER_LC }}/utools-backend:latest
backend.tags+=${{ steps.image_names.outputs.backend_image }}:${{ steps.git_sha.outputs.sha }} ${{ env.REGISTRY }}/${{ env.DOCKERHUB_USER_LC }}/utools-backend:${{ steps.vars.outputs.sha }}
frontend.tags=${{ steps.image_names.outputs.frontend_image }}:latest build-args: |
frontend.tags+=${{ steps.image_names.outputs.frontend_image }}:${{ steps.git_sha.outputs.sha }} GIT_COMMIT_SHA=${{ steps.vars.outputs.sha }}
SENTRY_DSN=${{ secrets.SENTRY_DSN }}
# Optionaler Zusatz-Tag ohne Rebuild: manifest neu taggen - name: Tag backend with extra_tag (manifest retag)
- name: Tag backend image with extra tag (manifest)
if: ${{ github.event.inputs.extra_tag && github.event.inputs.extra_tag != '' }} if: ${{ github.event.inputs.extra_tag && github.event.inputs.extra_tag != '' }}
run: | run: |
docker buildx imagetools create \ docker buildx imagetools create \
-t ${{ steps.image_names.outputs.backend_image }}:${{ github.event.inputs.extra_tag }} \ -t ${{ env.REGISTRY }}/${{ env.DOCKERHUB_USER_LC }}/utools-backend:${{ github.event.inputs.extra_tag }} \
${{ steps.image_names.outputs.backend_image }}:${{ steps.git_sha.outputs.sha }} ${{ env.REGISTRY }}/${{ env.DOCKERHUB_USER_LC }}/utools-backend:${{ steps.vars.outputs.sha }}
- name: Tag frontend image with extra tag (manifest) # -------- FRONTEND --------
- name: Build & Push frontend (multi-arch)
uses: docker/build-push-action@v6
with:
context: ./frontend
file: ./frontend/Dockerfile
push: true
platforms: linux/amd64,linux/arm64
tags: |
${{ env.REGISTRY }}/${{ env.DOCKERHUB_USER_LC }}/utools-frontend:latest
${{ env.REGISTRY }}/${{ env.DOCKERHUB_USER_LC }}/utools-frontend:${{ steps.vars.outputs.sha }}
build-args: |
GIT_COMMIT_SHA=${{ steps.vars.outputs.sha }}
SENTRY_DSN=${{ secrets.SENTRY_DSN }}
- name: Tag frontend with extra_tag (manifest retag)
if: ${{ github.event.inputs.extra_tag && github.event.inputs.extra_tag != '' }} if: ${{ github.event.inputs.extra_tag && github.event.inputs.extra_tag != '' }}
run: | run: |
docker buildx imagetools create \ docker buildx imagetools create \
-t ${{ steps.image_names.outputs.frontend_image }}:${{ github.event.inputs.extra_tag }} \ -t ${{ env.REGISTRY }}/${{ env.DOCKERHUB_USER_LC }}/utools-frontend:${{ github.event.inputs.extra_tag }} \
${{ steps.image_names.outputs.frontend_image }}:${{ steps.git_sha.outputs.sha }} ${{ env.REGISTRY }}/${{ env.DOCKERHUB_USER_LC }}/utools-frontend:${{ steps.vars.outputs.sha }}

View File

@@ -7,10 +7,10 @@ services:
args: args:
- GIT_COMMIT_SHA=${GIT_COMMIT_SHA:-unknown} - GIT_COMMIT_SHA=${GIT_COMMIT_SHA:-unknown}
- SENTRY_DSN=${SENTRY_DSN:-} - SENTRY_DSN=${SENTRY_DSN:-}
image: ghcr.io/mrunknownde/utools-backend:latest image: mrunknownde/utools-backend:latest
frontend: frontend:
# Definiert, wie das Image gebaut wird # Definiert, wie das Image gebaut wird
build: build:
context: ./frontend context: ./frontend
image: ghcr.io/mrunknownde/utools-frontend:latest image: mrunknownde/utools-frontend:latest