Solutions - HPC's Spack config
There should be a branch of this repo for each major Spack release. Branch 0.23 covers all 0.23.x Spack versions.
The very first user of this version of Spack and this repo should create an Spack-versioned directory to check out into, clone this repo and switch to the desired branch. This example is for Spack 0.23.x:
mkdir -p /home/ccspapp/Scratch/spack/0.23
cd /home/ccspapp/Scratch/spack/0.23
git clone https://github.com/UCL-ARC/hpc-spack.git --branch 0.23
Once the repo already exists, start from here. Our sites location is /shared/ucl/apps/spack/0.23
for 0.23.x which is defined in spack_sites.ini.
cd /home/ccspapp/Scratch/spack/0.23/hpc-spack
# initialise spacksites
source spacksites/myriad-utilities/init-spacksites-on-myriad.sh
# make your new site - we've been prefixing $site_name with initials
spacksites/spacksites create $site_name
# install your first compiler into your site - will use the buildcache as long as it exists
# $env_name will be the name of the environment you are creating, eg first_compiler.
spacksites/spacksites install-env $site_name $env_name first_compiler.yaml
# get ready to run spack commands as normal for this site
eval $(spacksites/spacksites spack-setup-env $site_name)
You can now run spack find
to show the installed packages, or spack info --all $package
to show available versions of that package to install.
There is more detailed info and possible considerations in Spacksites README.
Make a site for a small subset of software, test them, end up with a .yaml specifying what has been installed, decide those are the versions we want, push them into the buildcache so they can be picked up by everyone, work on the next subset until we have a large set of software packages and one large .yaml file while keeping different versions of the same build dependencies to a necessary minimum.
On new releases of Spack, rebuild the build cache, see if there are package versions that have been removed and new ones we want to include.
Our Spack-versioned buildcache is at /shared/ucl/apps/spack/0.23/buildcache
for 0.23.x.
This is specified in initial_site_mirrors.yaml and gets copied into $site_name/spack/etc/spack/mirrors.yaml
in any sites you create.
To push a package to the buildcache as ccspapp:
# take my site-installed [email protected] and all its dependencies, and put it into a buildcache at this location
spack buildcache push /shared/ucl/apps/spack/0.23/buildcache [email protected]
Or do this for an entire environment, in this case called myriad
:
spack -e myriad buildcache push /shared/ucl/apps/spack/0.23/buildcache
Once packages are pushed, update the index so they show in spack buildcache list
:
spack buildcache update-index /shared/ucl/apps/spack/0.23/buildcache/
We have two local package repos at the top level in this repository:
repos/dev
repos/ucl
The intent is that dev
is for specs that we are developing and don't consider to be fully tested.
ucl
is for non-dev specs, including updated versions from Spack's develop
branch in situations
where we need the updated version but it doesn't exist in the version of Spack we are currently using.
These repos are defined in spacksites/settings/initial_site_repos.yaml so all new sites will pick those up.
Spack will search through the repos in order to find requested specs, so it will find our versions first.
# show repos for the active site
spack repo list
==> 3 package repositories.
ucl.arc.hpc /lustre/scratch/scratch/ccspapp/spack/0.23/hpc-spack/repos/ucl
ucl.arc.hpc.dev /lustre/scratch/scratch/ccspapp/spack/0.23/hpc-spack/repos/dev
builtin /lustre/shared/ucl/apps/spack/0.23/hk-initial-stack/spack/var/spack/repos/builtin
If you have an existing site and we have added new repos that it does not have, add them to
spack/etc/spack/repos.yaml
in your site.
Spack documentation on Package Repositories.
If we pick up a spec from develop
that depends on virtual packages that don't exist yet in this version,
we need to change the package.py to use something concrete in our local copy - adding a comment to the
package that we have done this may be helpful! (Example of this from Spack 0.20 was zlib-api).
When there is a major version release, we need to:
- Create a new branch in this repo
- In that branch, edit the version in spack_sites.ini
- Update the sites_root in spack_sites.ini
- Update the buildcache location in initial_site_mirrors.yaml
- Check whether the major changes/deprecations for the new version require any alterations to the spack commands spacksites runs, initial_site_modules.yaml, any other config or format changes or changes in default behaviour.
- Check out the new branch in a new directory, as when starting from scratch above.
- Create the new sites_root in
/shared/ucl/apps/$version
- Create a new buildcache in the sites_root, checking whether the versions we build are still available in the new Spack version and updating our site .yaml files if they do not.
- Check our
ucl
local package repo to see if specs we got fromdevelop
now exist in builtin. If they do, delete the local one.
You can run spacksites and use the existing buildcache as your own user rather than ccspapp
. You will need to make these changes.
The instructions all assume that you have the default Myriad login environment (you can view the default .bashrc
and .bash_profile
in /etc/skel
).
Most importantly, you mustn't have any other python loaded or PYTHONPATH set, or other spack environment active, or things are likely to break in strange ways.
You may wish to make a private fork of this repo with the spack_sites.ini changes suitable for your install location, or you can create another script like this one to stash changes, pull, and update sites_root
and other settings in the .ini file for you.
spacksites/myriad-utilities/git-pull-on-myriad.sh
You will need to change init-spacksites-on-myriad.sh so it is suitable for your own user and install of spacksites rather than ccspapp
, or create your own similar init script. Right now that script hard-codes where the spacksites checkout location is.
The first two steps are the same as above:
# initialise spacksites (or replace this with your own init script)
source spacksites/myriad-utilities/init-spacksites-on-myriad.sh
# make your new site - this will be created in your specified site_root
spacksites/spacksites create $site_name
# get ready to run spack commands as normal for this site
eval $(spacksites/spacksites spack-setup-env $site_name)
The public gpg key for the buildcache exists in /shared/ucl/apps/spack/0.23/buildcache/build_cache/_pgp/
for version 0.23. This key belongs to the ccspapp
user.
# To use the buildcache you need to trust our existing public gpg key
spack gpg trust <keyfile>
# install your first compiler into your site - will use the buildcache as long as it exists
# $env_name will be the name of the environment you are creating, eg first_compiler.
spacksites/spacksites install-env $site_name $env_name first_compiler.yaml
You can now go ahead and install any other packages you want to build.
You can set a different build_stage in your site's config.yaml
file (suggested to use $XDG_RUNTIME_DIR
if you are on the login nodes).
Spack's default config.yaml for your site is in $site_root/$site_name/etc/spack/defaults/config.yaml
. Each site has its own.
Note: spacksites deliberately ignores any other local Spack config files to avoid clashes with other Spack setups you may have: Personal spack config - ignored