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

Use spack binary caches to greatly speed up the installation of spack environments #365

Closed
2 tasks
climbfuji opened this issue Oct 1, 2022 · 5 comments
Closed
2 tasks
Assignees
Labels
Epic For planning and administration INFRA JEDI Infrastructure NAVY United States Naval Research Lab NOAA-EMC OAR-EPIC NOAA Oceanic and Atmospheric Research and Earth Prediction Innovation Center

Comments

@climbfuji
Copy link
Collaborator

climbfuji commented Oct 1, 2022

Is your feature request related to a problem? Please describe.
Installing spack environments is slow, because everything gets compiled from source.

Describe the solution you'd like
spack binary caches allow caching installed packages locally and reuse them if the (unique) hash for the package is the same. This can greatly reduce the time to install environments, from hours to minutes, depending on how many packages have changed.

Additional context
The binary caches serve as a second local cache, in addition to the spack mirrors (see #364) to reduce network traffic and speed up the install process.

Test build caching based on 1.4.0 installations on the following systems (by creating the cache based on unified-env, install a new copy wherever, and time it):

@climbfuji
Copy link
Collaborator Author

We made significant progress on this in the first quarter of 2023. We are now using (simplified versions of) build caches for the CI tests running on self-hosted Github runners, which brought the build times down from over 6 hours to less than 30 minutes for the entire unified-dev environment.

There are a few issues that still need to be sorted out and that have to do with package relocation and the use of config:install_tree:padded_length:VALUE. We are avoiding this right now in the CI tests by always building in the same directory (i.e. using the same environment name) so that we don't have to pad the path when creating build caches.

I don't think it's realistic to have all this fleshed out so that we can roll it out on the HPCs and user systems, and have a hierarchical tree of binary caches in place (local, upstream on S3, ...). Therefore I defer completing this task to the next quarter / spack-stack release 1.4.0 by end of June 2023.

@AlexanderRichert-NOAA
Copy link
Collaborator

@ulmononian @mark-a-potts per our discussion today can you test out creating/using build caches on, say, Hera and Cheyenne and add those systems to the list at the top of this issue? The test installation doesn't need to be in an official space for now, as I think the next step will be to nail down locations.

@climbfuji climbfuji added the INFRA JEDI Infrastructure label Sep 21, 2023
@climbfuji climbfuji added NOAA-EMC OAR-EPIC NOAA Oceanic and Atmospheric Research and Earth Prediction Innovation Center labels Sep 29, 2023
@climbfuji climbfuji moved this from Todo to Done in spack-stack-1.7.0 (2024 Q1) Apr 4, 2024
@climbfuji climbfuji added the Epic For planning and administration label Apr 10, 2024
@climbfuji climbfuji added the NAVY United States Naval Research Lab label May 13, 2024
@eap
Copy link
Collaborator

eap commented Aug 5, 2024

What is the status of this? We are using the binary cache in our test runner system, is the cache being used elsewhere?

I just want to understand how to move forward on this bug or if it should be tracked in a number of separate platform issues.

@climbfuji
Copy link
Collaborator Author

This is going to get addressed in the next few weeks as part of our automation efforts - the issue here covers basically all supported platforms, not just the CI runner.

@climbfuji
Copy link
Collaborator Author

Closed via #1213

@github-project-automation github-project-automation bot moved this from In Progress to Done in spack-stack automation Dec 6, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Epic For planning and administration INFRA JEDI Infrastructure NAVY United States Naval Research Lab NOAA-EMC OAR-EPIC NOAA Oceanic and Atmospheric Research and Earth Prediction Innovation Center
Projects
Development

No branches or pull requests

6 participants