From aef8d0f6d128fccbeb9832efb6869ccb9f674c27 Mon Sep 17 00:00:00 2001 From: nyanmisaka Date: Wed, 13 Nov 2024 13:17:22 +0800 Subject: [PATCH] Explicitly set the target platform of Docker builds Signed-off-by: nyanmisaka --- build.py | 5 +++-- build.yaml | 3 +++ docker/Dockerfile | 6 ++++-- 3 files changed, 10 insertions(+), 4 deletions(-) diff --git a/build.py b/build.py index dd3090b..38237c4 100755 --- a/build.py +++ b/build.py @@ -309,6 +309,7 @@ def build_docker( DOTNET_ARCH = configurations["docker"]["archmaps"][_build_arch]["DOTNET_ARCH"] QEMU_ARCH = configurations["docker"]["archmaps"][_build_arch]["QEMU_ARCH"] IMAGE_ARCH = configurations["docker"]["archmaps"][_build_arch]["IMAGE_ARCH"] + TARGET_ARCH = configurations["docker"]["archmaps"][_build_arch]["TARGET_ARCH"] # Use a unique docker image name for consistency if is_stable: @@ -327,10 +328,10 @@ def build_docker( # Build the dockerfile log( - f">>> {docker_build_cmd} --build-arg PACKAGE_ARCH={PACKAGE_ARCH} --build-arg DOTNET_ARCH={DOTNET_ARCH} --build-arg QEMU_ARCH={QEMU_ARCH} --build-arg IMAGE_ARCH={IMAGE_ARCH} --build-arg JELLYFIN_VERSION={jellyfin_version} --file {repo_root_dir}/{dockerfile} --tag {imagename} {repo_root_dir}" + f">>> {docker_build_cmd} --build-arg PACKAGE_ARCH={PACKAGE_ARCH} --build-arg DOTNET_ARCH={DOTNET_ARCH} --build-arg QEMU_ARCH={QEMU_ARCH} --build-arg IMAGE_ARCH={IMAGE_ARCH} --build-arg TARGET_ARCH={TARGET_ARCH} --build-arg JELLYFIN_VERSION={jellyfin_version} --file {repo_root_dir}/{dockerfile} --tag {imagename} {repo_root_dir}" ) ret = os.system( - f"{docker_build_cmd} --build-arg PACKAGE_ARCH={PACKAGE_ARCH} --build-arg DOTNET_ARCH={DOTNET_ARCH} --build-arg QEMU_ARCH={QEMU_ARCH} --build-arg IMAGE_ARCH={IMAGE_ARCH} --build-arg JELLYFIN_VERSION={jellyfin_version} --file {repo_root_dir}/{dockerfile} --tag {imagename} {repo_root_dir}" + f"{docker_build_cmd} --build-arg PACKAGE_ARCH={PACKAGE_ARCH} --build-arg DOTNET_ARCH={DOTNET_ARCH} --build-arg QEMU_ARCH={QEMU_ARCH} --build-arg IMAGE_ARCH={IMAGE_ARCH} --build-arg TARGET_ARCH={TARGET_ARCH} --build-arg JELLYFIN_VERSION={jellyfin_version} --file {repo_root_dir}/{dockerfile} --tag {imagename} {repo_root_dir}" ) if ret > 0: exit(1) diff --git a/build.yaml b/build.yaml index e363b3f..627fa5b 100644 --- a/build.yaml +++ b/build.yaml @@ -100,16 +100,19 @@ docker: IMAGE_ARCH: amd64 PACKAGE_ARCH: amd64 QEMU_ARCH: x86_64 + TARGET_ARCH: amd64 arm64: DOTNET_ARCH: arm64 IMAGE_ARCH: arm64v8 PACKAGE_ARCH: arm64 QEMU_ARCH: aarch64 + TARGET_ARCH: arm64/v8 armhf: DOTNET_ARCH: arm IMAGE_ARCH: arm32v7 PACKAGE_ARCH: armhf QEMU_ARCH: arm + TARGET_ARCH: arm/v7 dockerfile: docker/Dockerfile imagename: jellyfin/jellyfin diff --git a/docker/Dockerfile b/docker/Dockerfile index 9234a56..3b89584 100644 --- a/docker/Dockerfile +++ b/docker/Dockerfile @@ -25,8 +25,10 @@ ARG PACKAGE_ARCH ARG DOTNET_ARCH # QEMU architecture (x86_64, aarch64, arm), set by build script ARG QEMU_ARCH -# Base Image archiecture (amd64, arm64v8, arm32v7), set by build script +# Base Image architecture (amd64, arm64v8, arm32v7), set by build script ARG IMAGE_ARCH +# Target platform architecture (amd64, arm64/v8, arm/v7), set by build script +ARG TARGET_ARCH # Jellyfin version ARG JELLYFIN_VERSION @@ -86,7 +88,7 @@ RUN dotnet publish Jellyfin.Server --configuration Release \ # Build the final combined image # FROM multiarch/qemu-user-static:x86_64-${QEMU_ARCH} as qemu -FROM ${IMAGE_ARCH}/debian:${OS_VERSION}-slim as combined +FROM --platform=linux/${TARGET_ARCH} ${IMAGE_ARCH}/debian:${OS_VERSION}-slim as combined ARG OS_VERSION ARG FFMPEG_PACKAGE