From 9f4ab2c7d1e8c089eac3d1843184ac74ffb312b7 Mon Sep 17 00:00:00 2001 From: Howard Zhang Date: Tue, 20 Apr 2021 07:08:20 +0000 Subject: [PATCH] build multiarch bootstrap image Signed-off-by: Howard Zhang --- .../project-infra-postsubmits.yaml | 8 +- .../project-infra-presubmits.yaml | 8 +- images/bootstrap/Dockerfile | 3 +- images/publish_multiarch_image.sh | 113 ++++++++++++++++++ 4 files changed, 123 insertions(+), 9 deletions(-) create mode 100755 images/publish_multiarch_image.sh diff --git a/github/ci/prow-deploy/files/jobs/kubevirt/project-infra/project-infra-postsubmits.yaml b/github/ci/prow-deploy/files/jobs/kubevirt/project-infra/project-infra-postsubmits.yaml index df2f3cdabad..7e375c8901a 100644 --- a/github/ci/prow-deploy/files/jobs/kubevirt/project-infra/project-infra-postsubmits.yaml +++ b/github/ci/prow-deploy/files/jobs/kubevirt/project-infra/project-infra-postsubmits.yaml @@ -83,7 +83,7 @@ postsubmits: memory: "1Gi" limits: memory: "1Gi" - - name: publish-bootstrap-image + - name: publish-multiarch-bootstrap-image always_run: false run_if_changed: "images/golang/.*|images/bootstrap/.*" annotations: @@ -104,16 +104,16 @@ postsubmits: - | cat "$QUAY_PASSWORD" | docker login --username $(cat "$QUAY_USER") --password-stdin=true quay.io cd images - ./publish_image.sh bootstrap quay.io kubevirtci + ./publish_multiarch_image.sh bootstrap quay.io kubevirtci ./publish_image.sh golang quay.io kubevirtci # docker-in-docker needs privileged mode securityContext: privileged: true resources: requests: - memory: "1Gi" + memory: "8Gi" limits: - memory: "1Gi" + memory: "8Gi" - name: publish-kubekins-e2e-image always_run: false run_if_changed: "images/kubekins-e2e/.*" diff --git a/github/ci/prow-deploy/files/jobs/kubevirt/project-infra/project-infra-presubmits.yaml b/github/ci/prow-deploy/files/jobs/kubevirt/project-infra/project-infra-presubmits.yaml index a834dc95e7b..fcd2ce359e7 100644 --- a/github/ci/prow-deploy/files/jobs/kubevirt/project-infra/project-infra-presubmits.yaml +++ b/github/ci/prow-deploy/files/jobs/kubevirt/project-infra/project-infra-presubmits.yaml @@ -85,7 +85,7 @@ presubmits: memory: "1Gi" limits: memory: "1Gi" - - name: build-bootstrap-image + - name: build-multiarch-bootstrap-image always_run: false run_if_changed: "images/bootstrap/.*" decorate: true @@ -101,7 +101,7 @@ presubmits: - "/usr/local/bin/runner.sh" - "/bin/bash" - "-ce" - - "cd images && ./publish_image.sh -b bootstrap quay.io kubevirtci" + - "cd images && ./publish_multiarch_image.sh -b bootstrap quay.io kubevirtci" # docker-in-docker needs privileged mode securityContext: privileged: true @@ -132,9 +132,9 @@ presubmits: privileged: true resources: requests: - memory: "1Gi" + memory: "8Gi" limits: - memory: "1Gi" + memory: "8Gi" - name: build-kubekins-e2e-image always_run: false run_if_changed: "images/kubekins-e2e/.*" diff --git a/images/bootstrap/Dockerfile b/images/bootstrap/Dockerfile index e203949963f..ce5807699c9 100644 --- a/images/bootstrap/Dockerfile +++ b/images/bootstrap/Dockerfile @@ -93,7 +93,8 @@ RUN mkdir /docker-graph # # Cache the most commonly used bazel versions in the container -RUN curl -Lo ./bazelisk https://github.com/bazelbuild/bazelisk/releases/download/v1.7.4/bazelisk-linux-amd64 && \ +ARG ARCH +RUN curl -Lo ./bazelisk https://github.com/bazelbuild/bazelisk/releases/download/v1.7.4/bazelisk-linux-${ARCH} && \ chmod +x ./bazelisk && mv ./bazelisk /usr/local/bin/bazelisk && \ cd /usr/local/bin && ln -s bazelisk bazel diff --git a/images/publish_multiarch_image.sh b/images/publish_multiarch_image.sh new file mode 100755 index 00000000000..7a0886d9a6e --- /dev/null +++ b/images/publish_multiarch_image.sh @@ -0,0 +1,113 @@ +#!/bin/bash -xe +archs=(amd64 arm64) + +main() { + local build_only + while getopts "bh" opt; do + case "$opt" in + b) + build_only=true + ;; + h) + help + exit 0 + ;; + *) + echo "Invalid argument: $opt" + help + exit 1 + esac + done + shift $((OPTIND-1)) + local build_target="${1:?}" + local registry="${2:?}" + local registry_org="${3:?}" + local full_image_name image_tag base_image + + image_tag="$(get_image_tag)" + full_image_name="$( + get_full_image_name \ + "$registry" \ + "$registry_org" \ + "${build_target##*/}" \ + "$image_tag" + )" + + ( + cd "$build_target" + base_image="$(get_base_image)" + + build_image "$build_target" "$full_image_name" "$base_image" + ) + [[ $build_only ]] && return + publish_image "$full_image_name" + publish_manifest "$full_image_name" +} + +help() { + cat <