Running OGS in a container

With Singularity

Prerequisites

  • Linux or macOS (you may run Singularity with Vagrant on Windows as well)
  • A running installation of Singularity 3.0 or higher

Get a container image

Option: Download a release image (preferred)

Simply download an image from the releases page.

Option: Download image from the latest master-branch build

Simply download an image from the latest master-branch build page.

Option: Create custom image with ogs-container-maker

Build images with ogs-container-maker on Jenkins (login required, ask Lars Bilke for access):

It will build all combinations of format, openmpi_versions and pm. When the build finishes you can download the container (*.sif files) at the jobs page under Build Artifacts.

Run OGS inside a Container (called from outside)

This starts the container, mounts your home directory inside the container, passes the current working directory and runs the ogs executable (in your home directory which is mounted inside the container) with the passed project file. Everything works as expected and is transparent to the user. When ogs finishes the container stops and you returns to the host system.

The --app ogs selects a pre-defined execution environment in the container (i.e. setting the PATH to /scif/apps/ogs/bin in which all the executables are located). You could also run without the --app-parameter but then you had to specify the full executable path in the container:

Running a benchmark:

You can run other contained executables as well, e.g. vtkdiff:

You can interactively explore the container with singularity shell (you can see that you are in the container because of the Singularity [container image file]:...> prefix of the shell):


This article was written by Lars Bilke. If you are missing something or you find an error please let us know. Generated with Hugo 0.64.1. Last revision: April 7, 2020
Commit: [web] Updated Singularity link. c0c229315  | Edit this page on