Skip to content

Parallelize manifest list create, push, and sign operations#4335

Open
saschagrunert wants to merge 1 commit intokubernetes:masterfrom
saschagrunert:perf/parallel-manifest-push
Open

Parallelize manifest list create, push, and sign operations#4335
saschagrunert wants to merge 1 commit intokubernetes:masterfrom
saschagrunert:perf/parallel-manifest-push

Conversation

@saschagrunert
Copy link
Member

What type of PR is this?

/kind feature

What this PR does / why we need it:

Parallelizes Phase 3 of container image publishing (manifest list create, push, sign) using errgroup with bounded concurrency. Currently 6 images are processed sequentially at ~1 min each. This brings it from ~5 min to ~1 min.

Which issue(s) this PR fixes:

None

Special notes for your reviewer:

Part of a series of krel stage performance improvements.

Does this PR introduce a user-facing change?

NONE

@k8s-ci-robot k8s-ci-robot added do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. release-note-none Denotes a PR that doesn't merit a release note. kind/feature Categorizes issue or PR as related to a new feature. labels Mar 20, 2026
@k8s-ci-robot
Copy link
Contributor

[APPROVALNOTIFIER] This PR is APPROVED

This pull-request has been approved by: saschagrunert

The full list of commands accepted by this bot can be found here.

The pull request process is described here

Details Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@k8s-ci-robot k8s-ci-robot added area/release-eng Issues or PRs related to the Release Engineering subproject needs-priority sig/release Categorizes an issue or PR as relevant to SIG Release. approved Indicates a PR has been approved by an approver from all required OWNERS files. labels Mar 20, 2026
@k8s-ci-robot k8s-ci-robot added size/L Denotes a PR that changes 100-499 lines, ignoring generated files. cncf-cla: yes Indicates the PR's author has signed the CNCF CLA. labels Mar 20, 2026
Process manifest lists in parallel using errgroup with bounded
concurrency instead of sequentially. Each image's manifest create,
push (with retry), and sign operations are independent.

Signed-off-by: Sascha Grunert <sgrunert@redhat.com>
@saschagrunert saschagrunert force-pushed the perf/parallel-manifest-push branch from 74e7417 to c753507 Compare March 20, 2026 08:54
@saschagrunert saschagrunert changed the title WIP: Parallelize manifest list create, push, and sign operations Parallelize manifest list create, push, and sign operations Mar 20, 2026
@k8s-ci-robot k8s-ci-robot removed the do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. label Mar 20, 2026
@saschagrunert
Copy link
Member Author

@kubernetes/release-engineering PTAL

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

approved Indicates a PR has been approved by an approver from all required OWNERS files. area/release-eng Issues or PRs related to the Release Engineering subproject cncf-cla: yes Indicates the PR's author has signed the CNCF CLA. kind/feature Categorizes issue or PR as related to a new feature. needs-priority release-note-none Denotes a PR that doesn't merit a release note. sig/release Categorizes an issue or PR as relevant to SIG Release. size/L Denotes a PR that changes 100-499 lines, ignoring generated files.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants