From cb555708dc1fc5b5245f67f32e2ede8bb992f250 Mon Sep 17 00:00:00 2001 From: Victor Lin <13424970+victorlin@users.noreply.github.com> Date: Tue, 21 Mar 2023 14:12:44 -0700 Subject: [PATCH] Update scripts to reflect 3-stage build Apart from this commit, it was necessary to create 2 new repositories in the nextstrain Docker Hub organization. --- devel/build | 42 +++++++++++++++++++++++++++++---------- devel/copy-images | 33 ++++++++++++++++++++---------- devel/delete-from-ghcr.js | 6 +++++- devel/pull-from-registry | 6 ++++-- 4 files changed, 62 insertions(+), 25 deletions(-) diff --git a/devel/build b/devel/build index 72e7d121..656b6176 100755 --- a/devel/build +++ b/devel/build @@ -53,20 +53,36 @@ if ! docker buildx inspect "$builder" &>/dev/null; then docker buildx create --name "$builder" --driver docker-container --driver-opt network=host fi -BUILDER_IMAGE=nextstrain/base-builder +BUILDER_BUILD_PLATFORM_IMAGE=nextstrain/base-builder-build-platform +BUILDER_TARGET_PLATFORM_IMAGE=nextstrain/base-builder-target-platform FINAL_IMAGE=nextstrain/base docker buildx build \ - --target builder \ + --target builder-build-platform \ --builder "$builder" \ --platform "$platform" \ --build-arg CACHE_DATE \ - --cache-from "$BUILDER_IMAGE:latest" \ - --cache-from "$BUILDER_IMAGE:$tag" \ - --cache-from "$registry/$BUILDER_IMAGE:latest" \ - --cache-from "$registry/$BUILDER_IMAGE:$tag" \ + --cache-from "$BUILDER_BUILD_PLATFORM_IMAGE:latest" \ + --cache-from "$BUILDER_BUILD_PLATFORM_IMAGE:$tag" \ + --cache-from "$registry/$BUILDER_BUILD_PLATFORM_IMAGE:latest" \ + --cache-from "$registry/$BUILDER_BUILD_PLATFORM_IMAGE:$tag" \ --cache-to type=inline \ - --tag "$registry/$BUILDER_IMAGE:$tag" \ + --tag "$registry/$BUILDER_BUILD_PLATFORM_IMAGE:$tag" \ + --push \ + --provenance false \ + . + +docker buildx build \ + --target builder-target-platform \ + --builder "$builder" \ + --platform "$platform" \ + --build-arg CACHE_DATE \ + --cache-from "$BUILDER_TARGET_PLATFORM_IMAGE:latest" \ + --cache-from "$BUILDER_TARGET_PLATFORM_IMAGE:$tag" \ + --cache-from "$registry/$BUILDER_TARGET_PLATFORM_IMAGE:latest" \ + --cache-from "$registry/$BUILDER_TARGET_PLATFORM_IMAGE:$tag" \ + --cache-to type=inline \ + --tag "$registry/$BUILDER_TARGET_PLATFORM_IMAGE:$tag" \ --push \ --provenance false \ . @@ -77,12 +93,16 @@ docker buildx build \ --platform "$platform" \ --build-arg GIT_REVISION \ --build-arg CACHE_DATE \ - --cache-from "$BUILDER_IMAGE:latest" \ - --cache-from "$BUILDER_IMAGE:$tag" \ + --cache-from "$BUILDER_BUILD_PLATFORM_IMAGE:latest" \ + --cache-from "$BUILDER_BUILD_PLATFORM_IMAGE:$tag" \ + --cache-from "$BUILDER_TARGET_PLATFORM_IMAGE:latest" \ + --cache-from "$BUILDER_TARGET_PLATFORM_IMAGE:$tag" \ --cache-from "$FINAL_IMAGE:latest" \ --cache-from "$FINAL_IMAGE:$tag" \ - --cache-from "$registry/$BUILDER_IMAGE:latest" \ - --cache-from "$registry/$BUILDER_IMAGE:$tag" \ + --cache-from "$registry/$BUILDER_BUILD_PLATFORM_IMAGE:latest" \ + --cache-from "$registry/$BUILDER_BUILD_PLATFORM_IMAGE:$tag" \ + --cache-from "$registry/$BUILDER_TARGET_PLATFORM_IMAGE:latest" \ + --cache-from "$registry/$BUILDER_TARGET_PLATFORM_IMAGE:$tag" \ --cache-from "$registry/$FINAL_IMAGE:latest" \ --cache-from "$registry/$FINAL_IMAGE:$tag" \ --cache-to type=inline \ diff --git a/devel/copy-images b/devel/copy-images index a9c372e5..c7a6e8fe 100755 --- a/devel/copy-images +++ b/devel/copy-images @@ -33,7 +33,8 @@ if [[ "$tag" = "" ]]; then exit 1 fi -BUILDER_IMAGE=nextstrain/base-builder +BUILDER_BUILD_PLATFORM_IMAGE=nextstrain/base-builder-build-platform +BUILDER_TARGET_PLATFORM_IMAGE=nextstrain/base-builder-target-platform FINAL_IMAGE=nextstrain/base @@ -77,26 +78,36 @@ copy-image() { # Copy $tag between registries. +echo "Copying $registry_in/$BUILDER_BUILD_PLATFORM_IMAGE:$tag to $registry_out/$BUILDER_BUILD_PLATFORM_IMAGE:$tag." +copy-image \ + "$registry_in/$BUILDER_BUILD_PLATFORM_IMAGE:$tag" \ + "$registry_out/$BUILDER_BUILD_PLATFORM_IMAGE:$tag" + +echo "Copying $registry_in/$BUILDER_TARGET_PLATFORM_IMAGE:$tag to $registry_out/$BUILDER_TARGET_PLATFORM_IMAGE:$tag." +copy-image \ + "$registry_in/$BUILDER_TARGET_PLATFORM_IMAGE:$tag" \ + "$registry_out/$BUILDER_TARGET_PLATFORM_IMAGE:$tag" + echo "Copying $registry_in/$FINAL_IMAGE:$tag to $registry_out/$FINAL_IMAGE:$tag." copy-image \ "$registry_in/$FINAL_IMAGE:$tag" \ "$registry_out/$FINAL_IMAGE:$tag" -echo "Copying $registry_in/$BUILDER_IMAGE:$tag to $registry_out/$BUILDER_IMAGE:$tag." -copy-image \ - "$registry_in/$BUILDER_IMAGE:$tag" \ - "$registry_out/$BUILDER_IMAGE:$tag" - if [[ "$push_latest" = true ]]; then # Copy $tag to latest. + echo "Copying $registry_in/$BUILDER_BUILD_PLATFORM_IMAGE:$tag to $registry_out/$BUILDER_BUILD_PLATFORM_IMAGE:latest." + copy-image \ + "$registry_in/$BUILDER_BUILD_PLATFORM_IMAGE:$tag" \ + "$registry_out/$BUILDER_BUILD_PLATFORM_IMAGE:latest" + + echo "Copying $registry_in/$BUILDER_TARGET_PLATFORM_IMAGE:$tag to $registry_out/$BUILDER_TARGET_PLATFORM_IMAGE:latest." + copy-image \ + "$registry_in/$BUILDER_TARGET_PLATFORM_IMAGE:$tag" \ + "$registry_out/$BUILDER_TARGET_PLATFORM_IMAGE:latest" + echo "Copying $registry_in/$FINAL_IMAGE:$tag to $registry_out/$FINAL_IMAGE:latest." copy-image \ "$registry_in/$FINAL_IMAGE:$tag" \ "$registry_out/$FINAL_IMAGE:latest" - - echo "Copying $registry_in/$BUILDER_IMAGE:$tag to $registry_out/$BUILDER_IMAGE:latest." - copy-image \ - "$registry_in/$BUILDER_IMAGE:$tag" \ - "$registry_out/$BUILDER_IMAGE:latest" fi diff --git a/devel/delete-from-ghcr.js b/devel/delete-from-ghcr.js index acb86acb..5a792f6f 100644 --- a/devel/delete-from-ghcr.js +++ b/devel/delete-from-ghcr.js @@ -9,7 +9,11 @@ module.exports = async ({fetch, octokit, tag, token}) => { org = 'nextstrain'; - packages = ['base', 'base-builder']; + packages = [ + 'base', + 'base-builder-build-platform', + 'base-builder-target-platform', + ]; // Try all packages before terminating with any errors. let errorEncountered = false; diff --git a/devel/pull-from-registry b/devel/pull-from-registry index 4a6a0fe0..43f4fba1 100755 --- a/devel/pull-from-registry +++ b/devel/pull-from-registry @@ -17,8 +17,10 @@ while getopts "r:t:" opt; do esac done -BUILDER_IMAGE=nextstrain/base-builder +BUILDER_BUILD_PLATFORM_IMAGE=nextstrain/base-builder-build-platform +BUILDER_TARGET_PLATFORM_IMAGE=nextstrain/base-builder-target-platform FINAL_IMAGE=nextstrain/base -docker pull "$registry/$BUILDER_IMAGE:$tag" +docker pull "$registry/$BUILDER_BUILD_PLATFORM_IMAGE:$tag" +docker pull "$registry/$BUILDER_TARGET_PLATFORM_IMAGE:$tag" docker pull "$registry/$FINAL_IMAGE:$tag"