-
Notifications
You must be signed in to change notification settings - Fork 260
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
Integrate with cache mount mechanism to improve devcontainer build performance #345
Comments
Thanks for bringing this up, this sounds like a good idea! I guess, this would be an addition to the devcontainer-feature.json only and not the devcontainer.json as that can use the Dockerfile to do the build-time mounts. On built vs runtime caching: Not keeping the caches in the image makes a lot of sense in general since that keeps the image small for transferring to/from a registry. If the user would want to have the cache in the dev container, maybe that could be bind/volume mounted or copied when creating the container. I see the other type would be |
In the build context, bind is primarily used to manage short-lived configuration files such as the source directory, While integrating bind into the Devcontainer environment is not strictly necessary as the current implementation already mounts the feature directory during the build, it could provide flexibility for use cases such as configuring OpenSSL by mounting a configuration to Anyway, implementing it as a generic specification like the devcontainer spec for mounts would unlock all features. Although I don't have the source code of the VSCode extension to dig into how the devcontainer artifacts generation is done. |
This appears to be a BuildKit feature. Docker Desktop comes with BuildKit preinstalled. The only issue might be Linux installs where BuildKit comes in a separate package (e.g., docker-buildx-plugin in Debian/Ubuntu) and might not be installed by default. We could make it mandatory though, this would also allow us to remove some compatibility code that deals with installs missing BuildKit. Podman is using buildah which seems to support cache mounts. |
According to the docs APT requires The example from the above link:
|
A few more things to think about:
We could try to address these in each feature using the cache mounts:
The advantage of having each participating feature deal with these would be the simplicity of the proposal. |
Another option to speed up APT specifically is to configure a caching proxy like https://wiki.debian.org/AptCacherNg. This might be possible in a way that is transparent to features and without amending the spec. |
This is something I was also thinking about, similarly in the nix ecosystem we have cachix which is a remote build cache and bazel also has his own. At some point this spec could evolve into something akin to a Pod with sidecar containers, or using layering of compose spec if we want to fully realize this vision. We can be quite inspired by how the WSL team is handling shared subsystems such as having |
this is all really great stuff. would you mind elaborating on this part more @shikanime ?
are absolute paths a firm requirement by docker or something? |
Docker itself does have an absolute path requirement on the target side. Devcontainer spec allows users to be switched within the container, but the timing and mechanism remain unclear. It's uncertain when, where, and how this user creation and switching occurs, but I have my doubt that this is during the runtime lifecycle of the container, therefore after the docker build steps. Also, I believe there are a few places in the spec that allow the use of certain variables, but the implementation details aren't really clear to me, I think there's a dockerfile that's templated behind the scene, so maybe having relative path is not an issue ? |
Stray thoughts, may or may not be relevant or helpful. Following up on your nix-adjacent lines of thought,I know Arch Linux's big thing is their rolling upgrades. I wonder if there's lessons to be applied here for the I think i have a decent idea of the lifecycle timelines. Nothing we can't brute force with some logging anyways. I wonder how we might utilize the XDG Base Directory specs? |
I don't know if it is relevant, but I am using an external volume mount in a docker compose file to share the Now if there was a way to make this work when the external mount is not present (like in a github codespace).... Perhaps ugly, but useful for me.
|
any update or current workaround for this? |
Yes
ti 17. jouluk. 2024 klo 8.02 Liu Zhen ***@***.***> kirjoitti:
… any update or current workaround for this?
—
Reply to this email directly, view it on GitHub
<#345 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/BIJZESPFBZTKB6TY3XHXNP32F647PAVCNFSM6AAAAAA74WRSDWVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDKNBXGU3TGMBXGU>
.
You are receiving this because you are subscribed to this thread.Message
ID: ***@***.***>
|
@HernandoR , I've been using the init life cycle script to invoke my own Buildx bake command with great success. I just fix the image tag name in the dev container config, and then have the bake command build for that tag before the dev container is created. I like it than I can fully codify the bake process for the dev container base image as a standalone file that even our CI can pre build if needed, or include arbitrary cache mount or backend arguments like for S3 or image registries to speed up building locally. |
Description
This proposal aims to integrate with cache mount caching mechanisms to enhance the performance of devcontainer builds. Rebuilding devcontainers frequently is a common practice due to various factors, such as frequently working on different projects, upgrading tool version or editing devcontainer specification. To address this issue, Buildkit introduced the
RUN --mount
feature to fix practice such asapk add --no-cache
orrm -rf /var/cache/apt/archives /var/lib/apt/lists/*
, which is actually utilized by the devcontainer building script for mounting features scripts. Exposing an API for features to leverage the cache mount would be beneficial for caching directories like/var/cache/apt/archives
.Motivation
Building containers can be a resource-intensive process, both in terms of compute and network resources. A notable example is installing home-manager in a container where a significant amount of developer experience programs are shared, such as oh my zsh configurations, custom shells, and versioning tooling. All of these contributions can increase the container size by gigabytes. The only known solution to this issue is to move the some steps towards hooks, as demonstrated in my script and Ken Muse's article. This approach allows for offloading the build task to hooks and utilizing mounts.
Proposed Solution
To address the aforementioned concerns, I propose introducing a new configuration option in the specification to enable the configuration of one or more mount type caches such as:
Implementation Challenges
While this proposal addresses the integration of caching mechanisms for devcontainer builds, it doesn't encompass solutions for user relative cache directories like local
$HOME/.cache/pip
directories under user home paths. It primarily solve global caching mechanisms, such as/var/cache
.Furthermore, the distinction between runtime and build-time caching should be carefully considered. Installing dependencies during the install.sh phase allows for immediate access to those dependencies for dependent features, while utilizing hooks enables caching to be shared with the user's runtime environment.
The text was updated successfully, but these errors were encountered: