Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
hpc-compendium
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Deploy
Releases
Package Registry
Container Registry
Model registry
Operate
Terraform modules
Monitor
Incidents
Service Desk
Analyze
Value stream analytics
Contributor analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Terms and privacy
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
ZIH
hpcsupport
hpc-compendium
Merge requests
!422
Resolve "Add more terms similar to "todo" to grep-forbidden-patterns.sh"
Code
Review changes
Check out branch
Download
Patches
Plain diff
Merged
Resolve "Add more terms similar to "todo" to grep-forbidden-patterns.sh"
223-check-more-todo-terms
into
preview
Overview
0
Commits
8
Pipelines
0
Changes
3
Merged
Jan Frenzel
requested to merge
223-check-more-todo-terms
into
preview
3 years ago
Overview
0
Commits
8
Pipelines
0
Changes
3
Expand
Closes
#223 (closed)
0
0
Merge request reports
Compare
preview
version 4
8c7fce3e
3 years ago
version 3
16f3b8f1
3 years ago
version 2
2dcb4ce2
3 years ago
version 1
a559b6ba
3 years ago
preview (base)
and
version 1
latest version
581b4d1d
8 commits,
3 years ago
version 4
8c7fce3e
7 commits,
3 years ago
version 3
16f3b8f1
6 commits,
3 years ago
version 2
2dcb4ce2
5 commits,
3 years ago
version 1
a559b6ba
4 commits,
3 years ago
3 files
+
125
−
98
Side-by-side
Compare changes
Side-by-side
Inline
Show whitespace changes
Show one file at a time
Files
3
Search (e.g. *.vue) (Ctrl+P)
doc.zih.tu-dresden.de/docs/software/custom_easy_build_environment.md
+
119
−
92
Options
# EasyBuild
# EasyBuild
Sometimes the
\<
a href="SoftwareModulesList" target="
\_
blank"
Sometimes the
[
modules installed in the cluster
](
modules.md
)
are not enough for your purposes and
title="List of Modules">modules installed in the cluster
\<
/a> are not
you need some other software or a different version of a software.
enough for your purposes and you need some other software or a different
version of a software.
For most commonly used software, chances are high that there is already a
*recipe*
that EasyBuild
provides, which you can use. But what is Easybuild?
\<
br />For most commonly used software, chances are high that there is
already a
*recipe*
that EasyBuild provides, which you can use. But what
[
EasyBuild
](
https://easybuilders.github.io/easybuild/
)
is the software used to build and install
is Easybuild?
software on ZIH systems.
\<
a href="
<https://easybuilders.github.io/easybuild/>
"
The aim of this page is to introduce users to working with EasyBuild and to utilizing it to create
target="
\_
blank">EasyBuild
\<
/a>
\<
span style="font-size: 1em;"> is the
modules
software used to build and install software on, and create modules for,
Taurus.
\<
/span>
## Prerequisites
\<
span style="font-size: 1em;">The aim of this page is to introduce
1.
[
Shell access
](
../access/ssh_login.md
)
to ZIH systems
users to working with EasyBuild and to utilizing it to create
1.
basic knowledge about:
modules
**.**
\<
/span>
-
[
the ZIH system
](
../jobs_and_resources/hardware_overview.md
)
-
[
the module system
](
modules.md
)
on ZIH systems
**Prerequisites:**
\<
a href="Login" target="
\_
blank">access
\<
/a> to the
Taurus system and basic knowledge about Linux,
\<
a href="SystemTaurus"
EasyBuild uses a configuration file called recipe or "EasyConfig", which contains all the
target="
\_
blank" title="SystemTaurus">Taurus
\<
/a> and the
\<
a
information about how to obtain and build the software:
href="RuntimeEnvironment" target="
\_
blank"
title="RuntimeEnvironment">modules system
\<
/a>on Taurus.
\<
span style="font-size: 1em;">EasyBuild uses a configuration file
called recipe or "EasyConfig", which contains all the information about
how to obtain and build the software:
\<
/span>
-
Name
-
Name
-
Version
-
Version
-
Toolchain (think: Compiler + some more)
-
Toolchain (think: Compiler + some more)
-
Download URL
-
Download URL
-
Buildsystem (e.g. configure && make or cmake && make)
-
Buildsystem (e.g.
`
configure && make
`
or
`
cmake && make
`
)
-
Config parameters
-
Config parameters
-
Tests to ensure a successful build
-
Tests to ensure a successful build
The "Buildsystem" part is implemented in so-called "EasyBlocks" and
The build system part is implemented in so-called "EasyBlocks" and contains the common workflow.
contains the common workflow. Sometimes those are specialized to
Sometimes, those are specialized to encapsulate behaviour specific to multiple/all versions of the
encapsulate behaviour specific to multiple/all versions of the software.
software. Everything is written in Python, which gives authors a great deal of flexibility.
\<
span style="font-size: 1em;">Everything is written in Python, which
gives authors a great deal of flexibility.
\<
/span>
## Set up a custom module environment and build your own modules
## Set up a custom module environment and build your own modules
Installation of the new software (or version) does not require any
Installation of the new software (or version) does not require any specific credentials.
specific credentials.
### Prerequisites
\<
br />Prerequisites:
1 An existing EasyConfig
1 a place to put your
1
.
An existing EasyConfig
modules.
\<
span style="font-size: 1em;">Step by step guide:
\<
/span>
1.
a place to put your modules.
1
\.
Create a
\<
a href="WorkSpaces" target="
\_
blank">workspace
\<
/a> where
### Step by step guide
you'll install your modules. You need a place where your modules will be
placed. This needs to be done only once :
ws_allocate -F scratch EasyBuild 50 #
**Step 1:**
Create a
[
workspace
](
../data_lifecycle/workspaces.md#allocate-a-workspace
)
where you
install your modules. You need a place where your modules are placed. This needs to be done only
once:
2
\.
Allocate nodes. You can do this with interactive jobs (see the
```
console
example below) and/or put commands in a batch file and source it. The
marie@login$
ws_allocate
-F
scratch EasyBuild 50
latter is recommended for non-interactive jobs, using the command sbatch
marie@login$
ws_list |
grep
'directory.*EasyBuild'
in place of srun. For the sake of illustration, we use an interactive
workspace directory : /scratch/ws/1/marie-EasyBuild
job as an example. The node parameters depend, to some extent, on the
```
architecture you want to use. ML nodes for the Power9 and others for the
x86. We will use Haswell nodes.
srun -p haswell -N 1 -c 4 --time=08:00:00 --pty /bin/bash
**Step 2:**
Allocate nodes. You can do this with interactive jobs (see the example below) and/or
put commands in a batch file and source it. The latter is recommended for non-interactive jobs,
using the command
`sbatch`
instead of
`srun`
. For the sake of illustration, we use an
interactive job as an example. Depending on the partitions that you want the module to be usable on
later, you need to select nodes with the same archtitecture. Thus, use nodes from partition ml
later, if you want to use the module on nodes of that partition. In this example, we assume that we
want to use the module on nodes with x86 architecture und thus, use Haswell nodes.
\*
Using EasyBuild on the login nodes is not allowed
\*
```
console
marie@login$
srun
--partition
=
haswell
--nodes
=
1
--cpus-per-task
=
4
--time
=
08:00:00
--pty
/bin/bash
-l
```
3
\.
Load EasyBuild module.
!!! warning
module load EasyBuild
Using EasyBuild on the login nodes is not allowed.
\<
br />4. Specify Workspace. The rest of the guide is based on it.
**Step 3:**
Load EasyBuild module.
Please create an environment variable called
\`
WORKSPACE
\`
with the
location of your Workspace:
WORKSPACE=<location_of_your_workspace> # For example: WORKSPACE=/scratch/ws/anpo879a-EasyBuild
```
console
module load EasyBuild
```
5
\.
Load the correct modenv according to your current or target
**Step 4:**
Specify the workspace. The rest of the guide is based on it. Please create an
architecture:
\`
ml modenv/scs5
\`
for x86 (default) or
\`
modenv/ml
\`
for
environment variable called
`WORKSPACE`
with the location of your workspace:
Power9 (ml partition). Load EasyBuild module
ml modenv/scs5
```
console
module load EasyBuild
marie@compute$
WORKSPACE
=
/scratch/ws/1/marie-EasyBuild
#see output of ws_list above
```
6
\.
Set up your environment
:
**Step 5:**
Load the correct modenv according to your current or target architecture
:
export EASYBUILD_ALLOW_LOADED_MODULES=EasyBuild,modenv/scs5
=== "x86 (default, e. g. partition haswell)"
export EASYBUILD_DETECT_LOADED_MODULES=unload
```
console
export EASYBUILD_BUILDPATH="/tmp/${USER}-EasyBuild${SLURM_JOB_ID:-}"
marie@compute$
module load modenv/scs5
export EASYBUILD_SOURCEPATH="${WORKSPACE}/sources"
```
export EASYBUILD_INSTALLPATH="${WORKSPACE}/easybuild-$(basename $(readlink -f /sw/installed)
)"
=== "Power9 (partition ml
)"
export EASYBUILD_INSTALLPATH_MODULES="${EASYBUILD_INSTALLPATH}/modules"
```
console
m
odule use "${EASYBUILD_INSTALLPATH_MODULES}/all"
m
arie@compute$
module load modenv/ml
export LMOD_IGNORE_CACHE=1
```
7
\.
\<
span style="font-size: 13px;">Now search for an existing
**Step 6:**
Load module
`EasyBuild`
EasyConfig:
\<
/span>
eb --search TensorFlow
```
console
marie@compute$
module load EasyBuild
```
\<
span style="font-size: 13px;">8. Build the EasyConfig and its
**Step 7:**
Set up your environment:
dependencies
\<
/span>
eb TensorFlow-1.8.0-fosscuda-2018a-Python-3.6.4.eb -r
```
console
marie@compute$
export
EASYBUILD_ALLOW_LOADED_MODULES
=
EasyBuild,modenv/scs5
marie@compute$
export
EASYBUILD_DETECT_LOADED_MODULES
=
unload
marie@compute$
export
EASYBUILD_BUILDPATH
=
"/tmp/
${
USER
}
-EasyBuild
${
SLURM_JOB_ID
:-}
"
marie@compute$
export
EASYBUILD_SOURCEPATH
=
"
${
WORKSPACE
}
/sources"
marie@compute$
export
EASYBUILD_INSTALLPATH
=
"
${
WORKSPACE
}
/easybuild-
$(
basename
$(
readlink
-f
/sw/installed
))
"
marie@compute$
export
EASYBUILD_INSTALLPATH_MODULES
=
"
${
EASYBUILD_INSTALLPATH
}
/modules"
marie@compute$
module use
"
${
EASYBUILD_INSTALLPATH_MODULES
}
/all"
marie@compute$
export
LMOD_IGNORE_CACHE
=
1
```
\<
span style="font-size: 13px;">After this is done (may take A LONG
**Step 8:**
Now search for an existing EasyConfig:
time), you can load it just like any other module.
\<
/span>
9
\.
To use your custom build modules you only need to rerun step 4, 5, 6
```
console
and execute the usual:
marie@compute$
eb
--search
TensorFlow
```
module load <name_of_your_module> # For example module load TensorFlow-1.8.0-fosscuda-2018a-Python-3.6.4
**Step 9:**
Build the EasyConfig and its dependencies
The key is the
\`
module use
\`
command which brings your modules into
```
console
scope so
\`
module load
\`
can find them and the LMOD_IGNORE_CACHE line
marie@compute$
eb TensorFlow-1.8.0-fosscuda-2018a-Python-3.6.4.eb
-r
which makes LMod pick up the custom modules instead of searching the
```
This may take a long time. After this is done, you can load it just like any other module.
**Step 10:**
To use your custom build modules you only need to rerun steps 4, 5, 6, 7 and execute
the usual:
```
console
marie@compute$
module load TensorFlow-1.8.0-fosscuda-2018a-Python-3.6.4
#replace with name of your module
```
The key is the
`module use`
command which brings your modules into scope so
`module load`
can find
them. The
`LMOD_IGNORE_CACHE`
line makes
`LMod`
pick up the custom modules instead of searching the
system cache.
system cache.
## Troubleshooting
## Troubleshooting
When building your EasyConfig fails, you can first check the log
When building your EasyConfig fails, you can first check the log mentioned and scroll to the bottom
mentioned and scroll to the bottom to see what went wrong.
to see what went wrong.
It might also be helpful to inspect the build environment EasyBuild uses. For that you can run:
```
console
marie@compute$
eb myEC.eb
--dump-env-script
`
```
This command creates a sourceable .env file with
`module load`
and
`export`
commands that show what
EB does before running, e.g., the configure step.
It might also be helpful to inspect the build environment EB uses. For
It might also be helpful to use
that you can run
\`
eb myEC.eb --dump-env-script
\`
which creates a
sourceable .env file with
\`
module load
\`
and
\`
export
\`
commands that
show what EB does before running, e.g., the configure step.
It might also be helpful to use '
\<
span style="font-size: 1em;">export
```
console
LMOD_IGNORE_CACHE=0'
\<
/span>
marie@compute$
export
LMOD_IGNORE_CACHE
=
0
```
Loading