Skip to content

Easystack files

This documentation covers aspects of specifying a software stack to install with Easybuild with easystack files.

Note: this is an experimental feature. Some of the mentioned functionality may be subject to change or be prone to errors.

Note

Some breaking changes were made to the experimental easystack support in EasyBuild v4.7.0.

Easystack files must now use the easyconfigs top-level key to list easyconfig filenames, as opposed to the software top-level key and separate subkeys like version, versionsuffix and toolchain to specify aspects of an easyconfig file that were supported before.

The basics

Easystack files describe an entire software stack, and can be used to specify to EasyBuild what to install.

Usage

To build software with Easystack, type:

eb --easystack example.yaml --experimental

where example.yaml is the file with specifications that you just created (more about this in the next section).

Structure of an easystack file

Easystack files are written in YAML syntax.

Essentially, an easystack file lists the easyconfig files you want to install, which are specified under the easyconfigs key.

For example:

easyconfigs:
  - PyTorch-1.12.0-foss-2022a-CUDA-11.7.0.eb
  - OpenFOAM-v2206-foss-2022a.eb

Note

You must use '-' to list the easyconfigs in an easystack file.

In addition, you can specify additional configuration options via the options subkey which will only apply to the installation of a particular easyconfig file.

For example:

easyconfigs:
  - PyTorch-1.12.0-foss-2022a-CUDA-11.7.0.eb:
      options:
        from-pr: 15924
        debug: True
  - Hypre-2.25.0-foss-2022a.eb:
  - OpenFOAM-v2206-foss-2022a.eb:
      options:
        installpath: /my/custom/installpath
        parallel: "1"

Note

You need to take care with some values in YAML, especially integers, booleans, etc.

If the specified value definitely must be a string value, you should use quotes ('...') to avoid that the YAML parser automatically converts the value to be of a specific type.

If you wish to use 1 (the number one), such as for the value to parallel option in the example above, then this should be quoted, to avoid it being treated as the boolean True.

In other cases, the automatic conversion is useful, like for the True used above, since debug is a boolean configuration option.

The configuration options that are valid for the eb command can be used (see eb --help), but the - or -- prefixes that are commonly used on the command line are omitted in easystack files.

Using the example easystack file above would be equivalent to running:

eb PyTorch-1.12.0-foss-2022a-CUDA-11.7.0.eb --from-pr 15924 --debug
eb Hypre-2.25.0-foss-2022a.eb
eb OpenFOAM-v2206-foss-2022a.eb --installpath /my/custom/installpath

Note

Whenever configuration options are not specified (as is the case for Hypre in the example easystack file above), you are still allowed to use ':' after the easyconfig filename: there is no difference in behaviour in ending with or without ':'.

Specifying short options in an easystack file is allowed, for example:

easyconfigs:
  - OpenFOAM-v2206-foss-2022a.eb:
      options:
        D: True

This is not recommended however, as short options are more difficult to interpret by humans.

If you use an option that can be set multiple times (namely amend and try-amend), you can supply the various values as a list under that option. For example, to set various site customization easyconfig parameters for a MATLAB without editing the easyconfig, one can use:

easyconfigs:
  - MATLAB-2023a.eb:
      options:
        try-amend:
          - license_server=hostname
          - license_server_port=12345
          - key=abc-123

Combining command line options with options in an easystack file

When building software with an easystack file, you can still add additional options on the command line as well. These apply to all items in the easystack file. For example, if you have an easystack file named my_easystack.yaml

easyconfigs:
  - PyTorch-1.12.0-foss-2022a-CUDA-11.7.0.eb:
      options:
        from-pr: 15924
        debug: True
  - OpenFOAM-v2206-foss-2022a.eb:

and you run with

eb --experimental --easystack my_easystack.yaml --dry-run

this will have the same effect as running

eb PyTorch-1.12.0-foss-2022a-CUDA-11.7.0.eb --dry-run --from-pr 15924 --debug
eb OpenFOAM-v2206-foss-2022a.eb --dry-run --installpath /my/custom/installpath

Note that options specified on the command line are placed before the easyconfig-specific options in the easystack file. EasyBuild will always respect the argument that was put last.

For example:

eb PyTorch-1.12.0-foss-2022a-CUDA-11.7.0.eb --dry-run --disable-dry-run

will effectively run without enabling dry run mode, since --disable-dry-run is specified after --dry-run.

Since easyconfig-specific configuration options specified in the easystack file are put last, they take priority over the the ones on the command line, if the same configuration option is specified in both.

For example, running:

eb --experimental --easystack my_easystack.yaml --disable-debug

will effectively cause PyTorch-1.12.0-foss-2022a-CUDA-11.7.0.eb to be installed with debug logging enabled, while OpenFOAM-v2206-foss-2022a.eb will be effectively installed without debug logging.

To be developed

In the future, we are planning to support additional also global options specified in the easystack file. For example:

options:
  robot: True
easyconfigs:
  - PyTorch-1.12.0-foss-2022a-CUDA-11.7.0.eb
  - OpenFOAM-v2206-foss-2022a.eb

would installed both PyTorch-1.12.0-foss-2022a-CUDA-11.7.0.eb and OpenFOAM-v2206-foss-2022a.eb using --robot (see issue #4105).

Additionally, we plan to support specifying for which EasyBuild version an easystack file was intended, which can be helpful in more accurately recreating a certain software stack (see issue #4106).

In the future, the --easystack option will probably be dropped, and EasyBuild will automatically detect the use of easystack files (see issue #4104).

Finally, we plan to support specifying labels, which would make it more easy to install only a certain subset of the items listed in an easystack file. For example, by labelling all GPU-capable software with a gpu label, one could easily choose to not build anything labeled gpu on a CPU node (see issue #3512).