Skip to content

Commit

Permalink
ci: add support for multiarch build
Browse files Browse the repository at this point in the history
  • Loading branch information
metaclips committed Nov 24, 2023
1 parent 43621ce commit 2482751
Show file tree
Hide file tree
Showing 5 changed files with 42 additions and 26 deletions.
60 changes: 37 additions & 23 deletions .github/workflows/distroless.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ defaults:
shell: bash

env:
ARCH_TO_BUILD_IMAGES: amd64
ARCH_TO_BUILD_IMAGES: amd64,arm64
ORGANIZATION: ${{ github.repository_owner }}

jobs:
Expand All @@ -34,6 +34,23 @@ jobs:
with:
ref: ${{ github.event.inputs.commit_sha }}

- uses: docker/login-action@bc135a1993a1d0db3e9debefa0cfcb70443cc94c # v2.1.0
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}

- uses: docker/setup-qemu-action@68827325e0b33c7199eb31dd4e31fbe9023e06e3

- id: buildx
uses: docker/setup-buildx-action@f95db51fddba0c2d1ec667646a06c2ce06100226
# TODO: change after new buildkit version gets fixed
# https://github.com/moby/buildkit/issues/3347
# https://github.com/docker/build-push-action/issues/761
with:
driver-opts: |
image=moby/buildkit:v0.10.6
- name: Generate Signing Key
run: docker run --rm -v "${PWD}":/work cgr.dev/chainguard/melange keygen

Expand All @@ -54,34 +71,31 @@ jobs:
docker load < base_image.tar
docker load < builder_image.tar
- uses: docker/login-action@bc135a1993a1d0db3e9debefa0cfcb70443cc94c # v2.1.0
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}


- name: Push Images
run: |
docker tag ghcr.io/${{ env.ORGANIZATION }}/ockam-elixir-base:latest-${{ env.ARCH_TO_BUILD_IMAGES }} ghcr.io/${{ env.ORGANIZATION }}/ockam-elixir-base:latest
docker push ghcr.io/${{ env.ORGANIZATION }}/ockam-elixir-base:latest
set -ex
docker image ls
manifests=""
docker tag ghcr.io/${{ env.ORGANIZATION }}/ockam-elixir-builder:latest-${{ env.ARCH_TO_BUILD_IMAGES }} ghcr.io/${{ env.ORGANIZATION }}/ockam-elixir-builder:latest
docker push ghcr.io/${{ env.ORGANIZATION }}/ockam-elixir-builder:latest
IFS=',' read -ra ARCHS <<< "$ARCH_TO_BUILD_IMAGES"
for arch in "${ARCHS[@]}"; do
echo "Pushing for ${arch}"
docker push "ghcr.io/${{ env.ORGANIZATION }}/ockam-elixir-base:latest-${arch}"
docker push "ghcr.io/${{ env.ORGANIZATION }}/ockam-elixir-builder:latest-${arch}"
- name: Get Image ref
id: image_ref
run: |
base=$(docker image inspect ghcr.io/${{ env.ORGANIZATION }}/ockam-elixir-base:latest | jq -r .[0].Id)
builder=$(docker image inspect ghcr.io/${{ env.ORGANIZATION }}/ockam-elixir-builder:latest | jq -r .[0].Id)
base_manifests="${base_manifests} --amend ghcr.io/${{ env.ORGANIZATION }}/ockam-elixir-base:latest-${arch}"
builder_manifests="${builder_manifests} --amend ghcr.io/${{ env.ORGANIZATION }}/ockam-elixir-builder:latest-${arch}"
done
echo "BUILDER=$builder" >> $GITHUB_OUTPUT
echo "BASE=$base" >> $GITHUB_OUTPUT
# Create manifest
docker manifest create ghcr.io/${{ env.ORGANIZATION }}/ockam-elixir-base:latest $base_manifests
docker manifest create ghcr.io/${{ env.ORGANIZATION }}/ockam-elixir-builder:latest $builder_manifests
- name: Install Cosign
uses: sigstore/cosign-installer@11086d25041f77fe8fe7b9ea4e48e3b9192b8f19
with:
cosign-release: 'v2.2.1'
base_image_sha=$(docker manifest push ghcr.io/${{ env.ORGANIZATION }}/ockam-elixir-base:latest)
builder_image_sha=$(docker manifest push ghcr.io/${{ env.ORGANIZATION }}/ockam-elixir-builder:latest)
echo "BUILDER=$builder_image_sha" >> $GITHUB_OUTPUT
echo "BASE=$base_image_sha" >> $GITHUB_OUTPUT
- uses: build-trust/.github/actions/image_cosign@custom-actions
with:
Expand Down
1 change: 1 addition & 0 deletions tools/docker/wolfi/base_image.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -21,3 +21,4 @@ contents:

archs:
- x86_64
- aarch64
1 change: 1 addition & 0 deletions tools/docker/wolfi/builder_image.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -30,3 +30,4 @@ contents:

archs:
- x86_64
- aarch64
1 change: 1 addition & 0 deletions tools/docker/wolfi/elixir_package.yaml
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
# docker run --rm --privileged -v "${PWD}":/work cgr.dev/chainguard/melange build elixir_package.yaml --arch amd64 -k melange.rsa.pub --signing-key melange.rsa
# Builds a pinned version of the elixir package
package:
name: elixir-1_14
Expand Down
5 changes: 2 additions & 3 deletions tools/docker/wolfi/erlang_package.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -48,8 +48,7 @@ pipeline:
--build="$CBUILD" \
--enable-threads \
--enable-shared-zlib \
--enable-ssl=dynamic-ssl-lib \
--enable-jit
--enable-ssl=dynamic-ssl-lib
- uses: autoconf/make

Expand All @@ -64,4 +63,4 @@ subpackages:
- uses: split/dev
dependencies:
runtime:
- erlang-24
- erlang-24

0 comments on commit 2482751

Please sign in to comment.