Browse Source

Simplify .NET multi-platform Dockerfile (#301)

* Improve dotnet multiplatform dockerfile

* Use implicit TARGETPLATFORM
Logan Bussell 2 years ago
parent
commit
d268b89fb1
1 changed files with 3 additions and 14 deletions
  1. 3 14
      worker/Dockerfile

+ 3 - 14
worker/Dockerfile

@@ -8,27 +8,16 @@
 # docker buildx build --platform "linux/arm64/v8" .
 # docker buildx build --platform "linux/arm64/v8" .
 FROM --platform=${BUILDPLATFORM} mcr.microsoft.com/dotnet/sdk:7.0 as build
 FROM --platform=${BUILDPLATFORM} mcr.microsoft.com/dotnet/sdk:7.0 as build
 ARG TARGETPLATFORM
 ARG TARGETPLATFORM
+ARG TARGETARCH
 ARG BUILDPLATFORM
 ARG BUILDPLATFORM
 RUN echo "I am running on $BUILDPLATFORM, building for $TARGETPLATFORM"
 RUN echo "I am running on $BUILDPLATFORM, building for $TARGETPLATFORM"
 
 
 WORKDIR /source
 WORKDIR /source
 COPY *.csproj .
 COPY *.csproj .
-RUN case ${TARGETPLATFORM} in \
-         "linux/amd64")  ARCH=x64  ;; \
-         "linux/arm64")  ARCH=arm64  ;; \
-         "linux/arm64/v8")  ARCH=arm64  ;; \
-         "linux/arm/v7") ARCH=arm  ;; \
-    esac \
-    && dotnet restore -r linux-${ARCH}
+RUN dotnet restore -a $TARGETARCH
 
 
 COPY . .
 COPY . .
-RUN  case ${TARGETPLATFORM} in \
-         "linux/amd64")  ARCH=x64  ;; \
-         "linux/arm64")  ARCH=arm64  ;; \
-         "linux/arm64/v8")  ARCH=arm64  ;; \
-         "linux/arm/v7") ARCH=arm  ;; \
-    esac \
-    && dotnet publish -c release -o /app -r linux-${ARCH} --self-contained false --no-restore
+RUN dotnet publish -c release -o /app -a $TARGETARCH --self-contained false --no-restore
 
 
 # app image
 # app image
 FROM mcr.microsoft.com/dotnet/runtime:7.0
 FROM mcr.microsoft.com/dotnet/runtime:7.0