title |
---|
Setup |
In this document we use the names Apptainer and Singularity interchangeably. See the [Introduction]({{ page.root }}{% link _episodes/01-introduction.md %}) for more details about existing Apptainer and Singularity versions and the differences between them.
Apptainer/Singularity has become popular and usually it is available in the institutional computing resources. Check if apptainer or singularity are available with
apptainer --version
singularity --version
If installed, you will see apptainer version ...
or singularity version ...
, depending on the flavor installed.
Apptainer is preferable but either one is OK, so if apptainer is there, no need to check for singularity (which most likely will be a link to apptainer).
This tutorial requires at least Apptainer 1.0.x or Singularity 3.5.x. Previous versions may not have all the required features.
If none is in your $PATH
or if the available version is too old,
you may still be able to use an updated apptainer via CVMFS: check if you have user namespaces enabled and CVMFS to run singularity that way:
[[ $(cat /proc/sys/user/max_user_namespaces) -gt 0 ]] && ls /cvmfs/oasis.opensciencegrid.org/mis/ &>/dev/null && { export PATH=/cvmfs/oasis.opensciencegrid.org/mis/apptainer/bin/:"$PATH"; echo "Success: Added to PATH"; singularity --version; } || echo "Failure: Unable to run Apptainer/Singularity via CVMFS"
If this works, it will be added to your path and you will see your apptainer/singularity version.
If your local computing system does not have Apptainer/Singularity installed, you may request it to your system administrator as suggested here.
You will need a Linux system (including WSL on Windows computers) to run Apptainer/Singularity natively. MacOS is not supported.
It is easiest to install if you have root access.
If the above is not possible and you cannot use the CVMFS distribution you have still an option if user namespace is enabled on your system:
- Check if user namespaces are enabled:
See these full instructions for more about checking for and enabling user namespaces.
# on Debian/Ubuntu grep -q 'kernel.unprivileged_userns_clone=1' /etc/sysctl.d/90-unprivileged_userns.conf && \ echo "User namespaces enabled, continue the Apptainer installation" || \ echo "User namespaces NOT enabled, your use of Apptainer will be very limited" # on RHEL/CentOS cat /proc/sys/user/max_user_namespaces` is bigger than 0 [[ $(cat /proc/sys/user/max_user_namespaces) -gt 0 ]] && \ echo "User namespaces enabled, continue the Apptainer installation" || \ echo "User namespaces NOT enabled, your use of Apptainer will be very limited"
- If enabled, install unprivileged Apptainer with one of these three methods (in order of preference):
- Chose your
INSTALL_DIR
and install there the relocatable Apptainer (recommended). Run:curl -s https://raw.githubusercontent.com/apptainer/apptainer/main/tools/install-unprivileged.sh | \ bash -s - INSTALL_DIR
- Alternatively install from source without root privileges.
- Or use cvmfsexec to get CVMFS. This is a bit more complex, you can follow the instrictions summarized also in this paper.
- Chose your
If user namespaces are not enabled, apptainers/singularity is not installed, and you have no root access to the host, then your use of apptainer/singularity will be very limited even if you install it with one of the three methods above. You need to request to your system administrator to either install Apptainer/Singularity or to enable user namespaces.
{% include links.md %}