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

Docker: Mount rust from image at build time instead of downloading it #1522

Open
wants to merge 6 commits into
base: master
Choose a base branch
from

Conversation

LaurentGoderre
Copy link

This ensures that rust is not left behind in the image

@@ -8,30 +10,16 @@ LABEL org.opencontainers.image.documentation="https://unit.nginx.org/installatio
LABEL org.opencontainers.image.vendor="NGINX Docker Maintainers <[email protected]>"
LABEL org.opencontainers.image.version="1.34.0"

RUN set -ex \
RUN --mount=type=bind,target=/rust,from=rust,rw \
Copy link

Choose a reason for hiding this comment

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

Because this is from= a stage, it would be mostly OK, but it's technically not officially supported in the DOI build system / dependency calculation, so adding it makes me a little nervous: https://github.com/docker-library/bashbrew/blob/f71d6ef63e1f5abe6d5cb06a62a3e5e42d68566e/cmd/bashbrew/docker.go#L96-L190

(For example, if we accept this, and then the FROM ... AS rust gets removed later, we won't necessarily remember the implications of that meaning that this line now implies from=rust:latest which will "just work" but not be accounted for correctly in our dependency calculations.)

Copy link
Author

Choose a reason for hiding this comment

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

Would using a target that isn't matching an image solve this such as rust-build?

Copy link
Member

Choose a reason for hiding this comment

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

Is this concern still valid?

pkg/docker/Dockerfile.go1.22 Outdated Show resolved Hide resolved
@LaurentGoderre LaurentGoderre force-pushed the optimize-docker branch 6 times, most recently from 8e1f00d to bbefca2 Compare December 24, 2024 17:20
@thresheek
Copy link
Member

Hmm, I think we can just re-use the "minimal" image instead of creating yet another "base" one. I'll try to give it a shot.

LaurentGoderre and others added 5 commits December 30, 2024 16:18
This ensures that rust is not left behind in the image
Instead of rebuilding unitd binaries every time a module image is built,
copy them from the minimal image.
We need to have this image built to copy the unitd binaries to the
modules images.
This helps to debug the issues.
@thresheek
Copy link
Member

I've pushed some commits that implement the "mount rust" idea, as well as removing build duplication into https://github.com/thresheek/unit/commits/optimize-docker-take2/. I can create another PR, or force-push to @LaurentGoderre's branch if @LaurentGoderre doesnt mind so we can review them here.

I've split the changes into reviewable items, so it should be easier to catch issues this way.

One thing I don't like is that the majority of "modules" don't really need a Rust image mounted since they won't be building any Rust code - the only users are minimal and wasm. I can live with it though if that's ok for Docker Library maintainers. We can probably also get rid of those with some more sed trickery and defines, but I'd rather leave it as is.

@LaurentGoderre
Copy link
Author

@thresheek feel free to use my branch however you need!

@thresheek
Copy link
Member

There we go. Please take a look.

@LaurentGoderre LaurentGoderre force-pushed the optimize-docker branch 2 times, most recently from bbefca2 to e846d28 Compare January 2, 2025 15:08
@LaurentGoderre
Copy link
Author

@thresheek LGTM!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants