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

Make CI smarter about when to rebuild the base images #670

Merged
merged 1 commit into from
Sep 30, 2024

Conversation

gerrod3
Copy link
Collaborator

@gerrod3 gerrod3 commented Sep 26, 2024

The base images action now takes the hash of the files used to build the base-image & ci-centos-image and then uses that as the key to pull the images from the cache. If it is a cache miss, then we build the images and upload to the cache like normal. If it is a cache hit then we import the images and check if each one needs to be rebuilt by running dnf check-update. This should reduce the amount of times we build the base & ci-centos images which is roughly half the CI run time! Also, I removed the temporary build tags as they were superfluous (and confusing).

@gerrod3 gerrod3 force-pushed the ci-smart-base-build branch 6 times, most recently from 9f991f5 to 71b4f04 Compare September 26, 2024 04:24
@gerrod3
Copy link
Collaborator Author

gerrod3 commented Sep 26, 2024

Current base-images CI results: first build (cache-miss) -> 18 mins, second build (cache-hit) -> 6 mins. The new slow part in the cache-hit is that each container we are checking have to update their repo metadata which is quite slow... Wonder if there is a way to do this once and reuse the same metadata across containers.

- name: Check for updates on cached images
if: steps.cache.outputs.cache-hit == 'true'
run: |
sudo podman run --rm --privileged multiarch/qemu-user-static --reset -p yes
Copy link
Member

Choose a reason for hiding this comment

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

What is this for?

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

This line allows us to run/build the arm64 images. Without it podman won't be able to run them.

Copy link
Member

Choose a reason for hiding this comment

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

That at the very least should be a comment here.

Just more background info for me: This runs a command in a container image named "multiarch/qemu-user-static" that flips a switch somewhere and exits right away?

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Yeah it runs a script in the container that modifies a file on the host to enable support. https://github.com/multiarch/qemu-user-static

.github/actions/base_images/action.yml Outdated Show resolved Hide resolved
podman build --platform linux/$ARCH --format docker --file images/pulp_ci_centos/Containerfile --tag pulp/pulp-ci-centos9:${TEMP_BASE_TAG}-${ARCH} --build-arg FROM_TAG=${TEMP_BASE_TAG}-${ARCH} .
for image in "${images[@]}"; do
echo "Building image ${image}"
arch=${image:(-5):5}
Copy link
Member

Choose a reason for hiding this comment

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

Dangerous assumption. Not all archs out there have 5 chars.

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

We are currently only using archs with 5 chars. What would you suggest I change it to?

Copy link
Member

Choose a reason for hiding this comment

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

Sooo, image can contain dashes. Maybe we can assume arch does not and split on the last "-". Or we use ":" instead as a separator.

Also I'd really prefer to consistently use capitalized (all caps) variable names in shell scripts.

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

I switched the separator to use ":" so now we can add support for archs with more than 5 chars.

podman build --platform linux/$ARCH --format docker --file images/pulp_ci_centos/Containerfile --tag pulp/pulp-ci-centos9:${TEMP_BASE_TAG}-${ARCH} --build-arg FROM_TAG=${TEMP_BASE_TAG}-${ARCH} .
for image in "${images[@]}"; do
echo "Building image ${image}"
arch=${image:(-5):5}
Copy link
Member

Choose a reason for hiding this comment

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

Sooo, image can contain dashes. Maybe we can assume arch does not and split on the last "-". Or we use ":" instead as a separator.

Also I'd really prefer to consistently use capitalized (all caps) variable names in shell scripts.

.github/actions/base_images/action.yml Outdated Show resolved Hide resolved
.github/actions/base_images/action.yml Outdated Show resolved Hide resolved
@gerrod3 gerrod3 force-pushed the ci-smart-base-build branch from 71b4f04 to 6e8c2cf Compare September 27, 2024 17:58
Copy link
Member

@mdellweg mdellweg left a comment

Choose a reason for hiding this comment

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

I'm ready to try this.

@gerrod3 gerrod3 merged commit 2dede81 into pulp:latest Sep 30, 2024
17 checks passed
@gerrod3 gerrod3 deleted the ci-smart-base-build branch September 30, 2024 16:23
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants