From 7bd8f80790cbd2810011dee5e91bf44b94b2e7b8 Mon Sep 17 00:00:00 2001 From: Steven Fackler Date: Sun, 8 Aug 2021 13:58:14 -0400 Subject: [PATCH 1/3] Also build ARM64 images --- .github/workflows/build.yml | 3 +++ 1 file changed, 3 insertions(+) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 2dc0415..129568b 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -38,6 +38,8 @@ jobs: steps: - uses: actions/checkout@v2 + - uses: docker/setup-buildx-action@v1 + - uses: docker/login-action@v1 if: github.event_name != 'pull_request' with: @@ -54,6 +56,7 @@ jobs: - uses: docker/build-push-action@v2 with: context: ${{ matrix.context }} + platforms: linux/amd64,linux/arm64 push: ${{ github.event_name != 'pull_request' }} tags: ${{ steps.meta.outputs.tags }} labels: ${{ steps.meta.outputs.labels }} From 1474ab244444aaabbfec31c385a948bc8ec81426 Mon Sep 17 00:00:00 2001 From: Steven Fackler Date: Sun, 8 Aug 2021 13:59:28 -0400 Subject: [PATCH 2/3] also setup qemu --- .github/workflows/build.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 129568b..3b6e6d4 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -38,6 +38,8 @@ jobs: steps: - uses: actions/checkout@v2 + - uses: docker/setup-qemu-action@v1 + - uses: docker/setup-buildx-action@v1 - uses: docker/login-action@v1 From 2896708e58424ce0495c83f0364106e4f93b31bf Mon Sep 17 00:00:00 2001 From: Steven Fackler Date: Sun, 8 Aug 2021 14:07:42 -0400 Subject: [PATCH 3/3] fix scripts for multi arch builds --- alpine3.12/Dockerfile | 15 +++++++++++---- bullseye/Dockerfile | 8 +++++++- bullseye/slim/Dockerfile | 8 +++++++- buster/Dockerfile | 8 +++++++- buster/slim/Dockerfile | 8 +++++++- 5 files changed, 39 insertions(+), 8 deletions(-) diff --git a/alpine3.12/Dockerfile b/alpine3.12/Dockerfile index c134855..f9a32f7 100644 --- a/alpine3.12/Dockerfile +++ b/alpine3.12/Dockerfile @@ -1,15 +1,22 @@ FROM alpine:3.12 +RUN apk add --no-cache \ + ca-certificates \ + gcc + ENV RUSTUP_HOME=/usr/local/rustup \ CARGO_HOME=/usr/local/cargo \ PATH=/usr/local/cargo/bin:$PATH RUN set -eux; \ - apk add --no-cache \ - ca-certificates \ - gcc; \ + apkArch="$(apk --print-arch)"; \ + case "$apkArch" in \ + x86_64) rustArch='x86_64-unknown-linux-musl' ;; \ + aarch64) rustArch='aarch64-unknown-linux-musl' ;; \ + *) echo >&2 "unsupported architecture: $apkArch"; exit 1 ;; \ + esac; \ \ - url="https://static.rust-lang.org/rustup/dist/x86_64-unknown-linux-musl/rustup-init"; \ + url="https://static.rust-lang.org/rustup/dist/${rustArch}/rustup-init"; \ wget "$url"; \ chmod +x rustup-init; \ ./rustup-init -y --no-modify-path --default-toolchain nightly; \ diff --git a/bullseye/Dockerfile b/bullseye/Dockerfile index c196166..37a7952 100644 --- a/bullseye/Dockerfile +++ b/bullseye/Dockerfile @@ -5,8 +5,14 @@ ENV RUSTUP_HOME=/usr/local/rustup \ PATH=/usr/local/cargo/bin:$PATH RUN set -eux; \ + dpkgArch="$(dpkg --print-architecture)"; \ + case "${dpkgArch##*-}" in \ + amd64) rustArch='x86_64-unknown-linux-gnu' ;; \ + arm64) rustArch='aarch64-unknown-linux-gnu' ;; \ + *) echo >&2 "unsupported architecture: ${dpkgArch}"; exit 1 ;; \ + esac; \ \ - url="https://static.rust-lang.org/rustup/dist/x86_64-unknown-linux-gnu/rustup-init"; \ + url="https://static.rust-lang.org/rustup/dist/${rustArch}/rustup-init"; \ wget "$url"; \ chmod +x rustup-init; \ ./rustup-init -y --no-modify-path --default-toolchain nightly; \ diff --git a/bullseye/slim/Dockerfile b/bullseye/slim/Dockerfile index 82b1add..6bea924 100644 --- a/bullseye/slim/Dockerfile +++ b/bullseye/slim/Dockerfile @@ -12,8 +12,14 @@ RUN set -eux; \ libc6-dev \ wget \ ; \ + dpkgArch="$(dpkg --print-architecture)"; \ + case "${dpkgArch##*-}" in \ + amd64) rustArch='x86_64-unknown-linux-gnu' ;; \ + arm64) rustArch='aarch64-unknown-linux-gnu' ;; \ + *) echo >&2 "unsupported architecture: ${dpkgArch}"; exit 1 ;; \ + esac; \ \ - url="https://static.rust-lang.org/rustup/dist/x86_64-unknown-linux-gnu/rustup-init"; \ + url="https://static.rust-lang.org/rustup/dist/${rustArch}/rustup-init"; \ wget "$url"; \ chmod +x rustup-init; \ ./rustup-init -y --no-modify-path --default-toolchain nightly; \ diff --git a/buster/Dockerfile b/buster/Dockerfile index 2160227..b9f1274 100644 --- a/buster/Dockerfile +++ b/buster/Dockerfile @@ -5,8 +5,14 @@ ENV RUSTUP_HOME=/usr/local/rustup \ PATH=/usr/local/cargo/bin:$PATH RUN set -eux; \ + dpkgArch="$(dpkg --print-architecture)"; \ + case "${dpkgArch##*-}" in \ + amd64) rustArch='x86_64-unknown-linux-gnu' ;; \ + arm64) rustArch='aarch64-unknown-linux-gnu' ;; \ + *) echo >&2 "unsupported architecture: ${dpkgArch}"; exit 1 ;; \ + esac; \ \ - url="https://static.rust-lang.org/rustup/dist/x86_64-unknown-linux-gnu/rustup-init"; \ + url="https://static.rust-lang.org/rustup/dist/${rustArch}/rustup-init"; \ wget "$url"; \ chmod +x rustup-init; \ ./rustup-init -y --no-modify-path --default-toolchain nightly; \ diff --git a/buster/slim/Dockerfile b/buster/slim/Dockerfile index 25c8bf6..4d7c0ec 100644 --- a/buster/slim/Dockerfile +++ b/buster/slim/Dockerfile @@ -12,8 +12,14 @@ RUN set -eux; \ libc6-dev \ wget \ ; \ + dpkgArch="$(dpkg --print-architecture)"; \ + case "${dpkgArch##*-}" in \ + amd64) rustArch='x86_64-unknown-linux-gnu' ;; \ + arm64) rustArch='aarch64-unknown-linux-gnu' ;; \ + *) echo >&2 "unsupported architecture: ${dpkgArch}"; exit 1 ;; \ + esac; \ \ - url="https://static.rust-lang.org/rustup/dist/x86_64-unknown-linux-gnu/rustup-init"; \ + url="https://static.rust-lang.org/rustup/dist/${rustArch}/rustup-init"; \ wget "$url"; \ chmod +x rustup-init; \ ./rustup-init -y --no-modify-path --default-toolchain nightly; \