Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: build cni installer image with cni builds #2324

Merged
merged 1 commit into from
Oct 30, 2023
Merged

Conversation

rbtr
Copy link
Contributor

@rbtr rbtr commented Oct 25, 2023

Reason for Change:

Up until now, we have released the CNI installer image as a separately versioned component from the CNI releases themselves. This has created a bit of versioning hell, as we struggle to maintain multiple release trains of the CNI (and thus CNI installer) when the CNI and installer version are not correlated.

This change flips the CNI installer image builder architecture. Previously, dropgz pulled in the released CNI tarballs as dependencies and produced a "dropgz-vX" omnibus image which contained uncorrelated CNI versions.
Here, we migrate instead to a CNI Dockerfile which imports dropgz as the dependency and is built in lockstep with (at least) azure-vnet builds, and versioned the same as them. Instead of deploying a "dropgz:v0.0.4" with unknown (at least, non-obvious) CNI payload versions, we produce a "cni-installer:v1.5.11" during the CNI release process with no ambiguity.

This is part 1 of this migration:

  • Build CNI installer images
  • Build azure-ipam installer images
  • Set up MCR publishing and syndication on new images
  • Migrate pipelines to new images
  • Migrate downstreams (AKS) to new images
  • Remove existing dropgz image infra (Dockerfiles, pipelines, etc)

Issue Fixed:

Requirements:

Notes:

@rbtr rbtr added enhancement cni Related to CNI. release/1.4 Change affects v1.4 release train release/latest Change affects latest release train needs-backport Change needs to be backported to previous release trains dropgz dropgz labels Oct 25, 2023
@rbtr rbtr requested a review from a team as a code owner October 25, 2023 22:50
@rbtr rbtr self-assigned this Oct 25, 2023
@rbtr rbtr requested a review from a team as a code owner October 25, 2023 22:50
@rbtr rbtr requested a review from ashvindeodhar October 25, 2023 22:50
@rbtr rbtr force-pushed the fix/dropgz-cni-versions branch from 265bef4 to 7d10576 Compare October 25, 2023 22:57
@rbtr rbtr force-pushed the fix/dropgz-cni-versions branch from 7d10576 to 96fc870 Compare October 25, 2023 23:00
@rbtr rbtr requested a review from paulyufan2 as a code owner October 25, 2023 23:00
@rbtr rbtr requested a review from tyler-lloyd October 25, 2023 23:03
@rbtr rbtr force-pushed the fix/dropgz-cni-versions branch 3 times, most recently from 59fde34 to 27a0712 Compare October 27, 2023 16:38
@pjohnst5
Copy link
Contributor

Just a qq, what does "omnibus" mean in this context? Sounds cool

"Previously, dropgz pulled in the released CNI tarballs as dependencies and produced a "dropgz-vX" omnibus image which contained uncorrelated CNI versions"

.pipelines/pipeline.yaml Outdated Show resolved Hide resolved
cni/linux.Dockerfile Show resolved Hide resolved
cni/linux.Dockerfile Show resolved Hide resolved
cni/linux.Dockerfile Show resolved Hide resolved
Makefile Outdated Show resolved Hide resolved
@rbtr rbtr mentioned this pull request Oct 27, 2023
14 tasks
@rbtr rbtr linked an issue Oct 27, 2023 that may be closed by this pull request
14 tasks
@rbtr rbtr force-pushed the fix/dropgz-cni-versions branch from 27a0712 to 37a7d96 Compare October 27, 2023 18:41
@rbtr rbtr force-pushed the fix/dropgz-cni-versions branch 2 times, most recently from c4e808b to 07797dd Compare October 27, 2023 18:54
@rbtr
Copy link
Contributor Author

rbtr commented Oct 27, 2023

@camrynl @vipul-21 @pjohnst5
I have updated this change to be additive only - creating the new image and infra for that. No changes to existing dropgz infra/tests at this time. This linked tracking issue describes the plan for building out this change and migrating to it.

@rbtr rbtr enabled auto-merge (squash) October 27, 2023 19:02
@rbtr rbtr requested review from pjohnst5 and vipul-21 October 27, 2023 22:17
@rbtr rbtr force-pushed the fix/dropgz-cni-versions branch from 07797dd to 99fb8ff Compare October 27, 2023 22:32
@jpayne3506
Copy link
Contributor

Remove existing dropgz image infra (Dockerfiles, pipelines, etc)

What is the expected impact from using older infra as this migration happens?

Makefile Show resolved Hide resolved
@@ -159,6 +159,20 @@ stages:
name: "$(BUILD_POOL_NAME_LINUX_AMD64)"
strategy:
matrix:
cni_linux_amd64:
Copy link
Contributor

@jpayne3506 jpayne3506 Oct 27, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Unless this gets renamed back to cni-dropgz, which from the PR description it is indicating that it will be,

Instead of deploying a "dropgz:v0.0.4" with unknown (at least, non-obvious) CNI payload versions, we produce a "cni-dropgz:v1.5.11"

we need to add this to the cleanup script regex for acnpublic

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

will follow up

@rbtr rbtr force-pushed the fix/dropgz-cni-versions branch from 99fb8ff to cb45f49 Compare October 28, 2023 01:59
@nddq nddq force-pushed the fix/dropgz-cni-versions branch from cb45f49 to 02d1fbc Compare October 28, 2023 17:46
@rbtr rbtr force-pushed the fix/dropgz-cni-versions branch from 02d1fbc to 3ea0176 Compare October 30, 2023 16:00
@rbtr rbtr disabled auto-merge October 30, 2023 21:09
@rbtr rbtr merged commit 7e5994d into master Oct 30, 2023
82 checks passed
@rbtr rbtr deleted the fix/dropgz-cni-versions branch October 30, 2023 21:51
rbtr added a commit that referenced this pull request Jul 22, 2024
rbtr added a commit that referenced this pull request Sep 26, 2024
rbtr added a commit that referenced this pull request Sep 27, 2024
rbtr added a commit that referenced this pull request Sep 27, 2024
rbtr added a commit that referenced this pull request Sep 27, 2024
rbtr added a commit that referenced this pull request Sep 27, 2024
rbtr added a commit that referenced this pull request Sep 27, 2024
rbtr added a commit that referenced this pull request Sep 27, 2024
rbtr added a commit that referenced this pull request Sep 27, 2024
rbtr added a commit that referenced this pull request Sep 30, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
cni Related to CNI. dropgz dropgz enhancement needs-backport Change needs to be backported to previous release trains release/latest Change affects latest release train release/1.4 Change affects v1.4 release train
Projects
None yet
Development

Successfully merging this pull request may close these issues.

CNI Installer migration
5 participants