Skip to content
Snippets Groups Projects
Commit 858bf44d authored by Lars Bilke's avatar Lars Bilke
Browse files

centos:8 base image support.

parent 1260fd50
No related branches found
No related tags found
No related merge requests found
...@@ -59,17 +59,12 @@ Check help for more options: ...@@ -59,17 +59,12 @@ Check help for more options:
``` ```
$ ogscm --help $ ogscm --help
usage: ogscm [-h] [--version] [--out OUT] [--file FILE] [--print] usage: ogscm [-h] [--version] [--out OUT] [--file FILE] [--print] [--format [{docker,singularity} [{docker,singularity} ...]]]
[--format [{docker,singularity} [{docker,singularity} ...]]] [--pm [{system,conan,spack,off} [{system,conan,spack,off} ...]]] [--ompi [OMPI [OMPI ...]]] [--ogs [OGS [OGS ...]]]
[--pm [{system,conan,spack,off} [{system,conan,spack,off} ...]]] [--cmake_args [CMAKE_ARGS [CMAKE_ARGS ...]]] [--build] [--upload] [--registry REGISTRY] [--tag TAG] [--convert] [--runtime-only] [--ccache]
[--ompi [OMPI [OMPI ...]]] [--ogs [OGS [OGS ...]]] [--parallel PARALLEL] [--base_image BASE_IMAGE] [--compiler COMPILER] [--compiler_version COMPILER_VERSION] [--gui] [--docs] [--jenkins]
[--cmake_args [CMAKE_ARGS [CMAKE_ARGS ...]]] [--build] [--gitlab] [--cvode] [--cppcheck] [--iwyy] [--gcovr] [--mpi_benchmarks] [--dev] [--insitu] [--pip [package [package ...]]]
[--upload] [--registry REGISTRY] [--convert] [--runtime-only] [--packages [packages [packages ...]]] [--clean] [--deploy [DEPLOY]]
[--ccache] [--parallel PARALLEL] [--base_image BASE_IMAGE]
[--compiler COMPILER] [--compiler_version COMPILER_VERSION]
[--gui] [--docs] [--jenkins] [--cvode] [--cppcheck] [--iwyy]
[--gcovr] [--mpi_benchmarks] [--dev] [--insitu]
[--pip [package [package ...]]] [--clean] [--deploy [DEPLOY]]
optional arguments: optional arguments:
-h, --help show this help message and exit -h, --help show this help message and exit
...@@ -83,69 +78,56 @@ Combinatorial options: ...@@ -83,69 +78,56 @@ Combinatorial options:
--format [{docker,singularity} [{docker,singularity} ...]] --format [{docker,singularity} [{docker,singularity} ...]]
--pm [{system,conan,spack,off} [{system,conan,spack,off} ...]] --pm [{system,conan,spack,off} [{system,conan,spack,off} ...]]
Package manager to install third-party dependencies Package manager to install third-party dependencies (default: ['conan'])
(default: ['conan'])
--ompi [OMPI [OMPI ...]] --ompi [OMPI [OMPI ...]]
OpenMPI version, e.g. 2.1.1, 2.1.5, 3.0.1, 3.1.2 OpenMPI version, e.g. 2.1.1, 2.1.5, 3.0.1, 3.1.2 (default: ['off'])
(default: ['off'])
--ogs [OGS [OGS ...]] --ogs [OGS [OGS ...]]
OGS GitHub repo in the form 'user/repo@branch' OR OGS GitHub repo in the form 'user/repo@branch' OR 'user/repo@@commit' to checkout a specific commit OR a path to a local subdirectory
'user/repo@@commit' to checkout a specific commit OR a to the git cloned OGS sources OR 'off' to disable OGS building (default: ['ufz/ogs@master'])
path to a local subdirectory to the git cloned OGS
sourcesOR 'off' to disable OGS building (default:
['ufz/ogs@master'])
--cmake_args [CMAKE_ARGS [CMAKE_ARGS ...]] --cmake_args [CMAKE_ARGS [CMAKE_ARGS ...]]
CMake argument sets have to be quoted and **must** CMake argument sets have to be quoted and **must** start with a space. e.g. --cmake_args ' -DFIRST=TRUE -DFOO=BAR' ' -DSECOND=TRUE'
start with a space. e.g. --cmake_args ' -DFIRST=TRUE (default: [''])
-DFOO=BAR' ' -DSECOND=TRUE' (default: [''])
Image build options: Image build options:
--build, -B Build the images from the definition files (default: --build, -B Build the images from the definition files (default: False)
False)
--upload, -U Upload Docker image to registry (default: False) --upload, -U Upload Docker image to registry (default: False)
--registry REGISTRY The docker registry the image is tagged and uploaded --registry REGISTRY The docker registry the image is tagged and uploaded to. (default: registry.opengeosys.org/ogs/ogs)
to. (default: registry.opengeosys.org/ogs/ogs) --tag TAG The full docker image tag. Overwrites --registry. (default: )
--convert, -C Convert Docker image to Singularity image (default: --convert, -C Convert Docker image to Singularity image (default: False)
False) --runtime-only, -R Generate multi-stage Dockerfiles for small runtime images (default: False)
--runtime-only, -R Generate multi-stage Dockerfiles for small runtime
images (default: False)
--ccache Enables ccache build caching. (default: False) --ccache Enables ccache build caching. (default: False)
--parallel PARALLEL, -j PARALLEL --parallel PARALLEL, -j PARALLEL
The number of cores to use for compilation. (default: The number of cores to use for compilation. (default: 10)
10)
Additional options: Additional options:
--base_image BASE_IMAGE --base_image BASE_IMAGE
The base image. (default: ubuntu:18.04) The base image. (centos:8 is supported too) (default: ubuntu:19.10)
--compiler COMPILER The compiler to use. Possible options: off, gcc, clang --compiler COMPILER The compiler to use. Possible options: off, gcc, clang (default: gcc)
(default: gcc)
--compiler_version COMPILER_VERSION --compiler_version COMPILER_VERSION
Compiler version. (default: ) Compiler version. (default: )
--gui Builds the GUI (Data Explorer) (default: False) --gui Builds the GUI (Data Explorer) (default: False)
--docs Setup documentation requirements (Doxygen) (default: --docs Setup documentation requirements (Doxygen) (default: False)
False)
--jenkins Setup Jenkins slave (default: False) --jenkins Setup Jenkins slave (default: False)
--gitlab Setup for GitLab-CI (default: False)
--cvode Install and configure with cvode (default: False) --cvode Install and configure with cvode (default: False)
--cppcheck Install cppcheck (default: False) --cppcheck Install cppcheck (default: False)
--iwyy Install include-what-you-use (default: False) --iwyy Install include-what-you-use (default: False)
--gcovr Install gcovr (default: False) --gcovr Install gcovr (default: False)
--mpi_benchmarks Installs OSU MPI benchmarks as scif app and mpi_bw, --mpi_benchmarks Installs OSU MPI benchmarks as scif app and mpi_bw, mpi_ring,mpi_hello (default: False)
mpi_ring,mpi_hello (default: False)
--dev Installs development tools (vim, gdb) (default: False) --dev Installs development tools (vim, gdb) (default: False)
--insitu Builds with insitu capabilities (default: False) --insitu Builds with insitu capabilities (default: False)
--pip [package [package ...]] --pip [package [package ...]]
Install additional Python packages (default: ['']) Install additional Python packages (default: [])
--packages [packages [packages ...]]
Install additional OS packages (default: [])
Maintenance: Maintenance:
--clean Cleans up generated files in default directories. --clean Cleans up generated files in default directories. (default: False)
(default: False)
Image deployment: Image deployment:
--deploy [DEPLOY], -D [DEPLOY] --deploy [DEPLOY], -D [DEPLOY]
Deploys to all configured hosts (in Deploys to all configured hosts (in config/deploy_hosts.yml) with no additional arguments or to the specified host. Implies --build
config/deploy_hosts.yml) with no additional arguments and --convert arguments. (default: )
or to the specified host. Implies --build and
--convert arguments. (default: )
``` ```
## Advanced usage ## Advanced usage
......
...@@ -112,7 +112,7 @@ class ogs(bb_base, hpccm.templates.CMakeBuild, hpccm.templates.rm): ...@@ -112,7 +112,7 @@ class ogs(bb_base, hpccm.templates.CMakeBuild, hpccm.templates.rm):
self.__cmake_args.append("-DOGS_USE_PETSC=ON") self.__cmake_args.append("-DOGS_USE_PETSC=ON")
if conan: if conan:
self.__cmake_args.append("-DOGS_CONAN_USE_SYSTEM_OPENMPI=ON") self.__cmake_args.append("-DOGS_CONAN_USE_SYSTEM_OPENMPI=ON")
if conan: if not conan:
self.__cmake_args.append('-DOGS_USE_CONAN=OFF') self.__cmake_args.append('-DOGS_USE_CONAN=OFF')
# Configure and build # Configure and build
......
...@@ -40,7 +40,7 @@ class ogs_base(bb_base): ...@@ -40,7 +40,7 @@ class ogs_base(bb_base):
packages=['virtualenv', 'pre-commit', 'cmake-format']) packages=['virtualenv', 'pre-commit', 'cmake-format'])
self += packages(ospackages=self.__ospackages, self += packages(ospackages=self.__ospackages,
apt_ppas=['ppa:git-core/ppa'], apt_ppas=['ppa:git-core/ppa'],
epel=True) epel=True, powertools=True)
self += shell(commands=self.__commands) self += shell(commands=self.__commands)
def __setup(self): def __setup(self):
......
...@@ -284,7 +284,7 @@ def main(): # pragma: no cover ...@@ -284,7 +284,7 @@ def main(): # pragma: no cover
# LD_LIBRARY_PATH) as host var overwrites container var. See # LD_LIBRARY_PATH) as host var overwrites container var. See
# https://github.com/sylabs/singularity/pull/2669 # https://github.com/sylabs/singularity/pull/2669
# Stage0 += boost(version='1.66.0') # header only? # Stage0 += boost(version='1.66.0') # header only?
Stage0 += packages(ospackages=['libboost-dev']) Stage0 += packages(apt=['libboost-dev'], yum=['boost-devel'], epel=True)
# Stage0 += environment(variables={'BOOST_ROOT': '/usr/local/boost'}) # Stage0 += environment(variables={'BOOST_ROOT': '/usr/local/boost'})
Stage0 += eigen() Stage0 += eigen()
vtk_cmake_args = [ vtk_cmake_args = [
...@@ -293,13 +293,20 @@ def main(): # pragma: no cover ...@@ -293,13 +293,20 @@ def main(): # pragma: no cover
'-DVTK_Group_StandAlone=OFF' '-DVTK_Group_StandAlone=OFF'
] ]
if args.gui: if args.gui:
Stage0 += packages(ospackages=[ Stage0 += packages(apt=[
'libgeotiff-dev', 'libgeotiff-dev',
'libqt5x11extras5-dev', 'libshp-dev',
'libqt5xmlpatterns5-dev', 'libqt5x11extras5-dev',
'libshp-dev', 'libqt5xmlpatterns5-dev',
'qt5-default' 'qt5-default'
]) ],
yum=[
'libgeotiff-devel',
'shapelib-devel',
'qt5-qtbase',
'qt5-qtxmlpatterns',
'qt5-qtx11extras'
])
vtk_cmake_args = [ vtk_cmake_args = [
'-DVTK_BUILD_QT_DESIGNER_PLUGIN=OFF', '-DVTK_BUILD_QT_DESIGNER_PLUGIN=OFF',
'-DVTK_Group_Qt=ON', '-DVTK_Group_Qt=ON',
...@@ -358,11 +365,14 @@ def main(): # pragma: no cover ...@@ -358,11 +365,14 @@ def main(): # pragma: no cover
Stage0 += raw(docker=f"ARG OGS_COMMIT_HASH={info.commit_hash}") Stage0 += raw(docker=f"ARG OGS_COMMIT_HASH={info.commit_hash}")
scif_file = f"{info.out_dir}/ogs.scif" scif_file = f"{info.out_dir}/ogs.scif"
definition_file_path = os.path.join(info.out_dir, info.definition_file)
if info.ogsdir: if info.ogsdir:
context_path_size = len(ogs_version) context_path_size = len(ogs_version)
print(f"chdir to {ogs_version}")
os.chdir(ogs_version) os.chdir(ogs_version)
mount_args = f'{mount_args} --mount=type=bind,target=/scif/apps/ogs/src,rw' mount_args = f'{mount_args} --mount=type=bind,target=/scif/apps/ogs/src,rw'
scif_file = f"{info.out_dir[context_path_size+1:]}/ogs.scif" scif_file = f"{info.out_dir[context_path_size+1:]}/ogs.scif"
definition_file_path = f"{info.out_dir[context_path_size+1:]}/{info.definition_file}"
ogs_app = scif(_arguments=mount_args, name='ogs', file=scif_file) ogs_app = scif(_arguments=mount_args, name='ogs', file=scif_file)
ogs_app += ogs(repo=info.repo, ogs_app += ogs(repo=info.repo,
...@@ -391,14 +401,12 @@ def main(): # pragma: no cover ...@@ -391,14 +401,12 @@ def main(): # pragma: no cover
stages_string += "\n\n" + str(Stage1) stages_string += "\n\n" + str(Stage1)
# ---------------------------- recipe end ----------------------------- # ---------------------------- recipe end -----------------------------
definition_file_path = os.path.join(info.out_dir, info.definition_file)
with open(definition_file_path, 'w') as f: with open(definition_file_path, 'w') as f:
print(stages_string, file=f) print(stages_string, file=f)
if args.print: if args.print:
print(stages_string) print(stages_string)
else: else:
print(f'Created definition {definition_file_path}') print(f'Created definition {os.path.abspath(definition_file_path)}')
# Create image # Create image
if not args.build: if not args.build:
...@@ -417,8 +425,6 @@ def main(): # pragma: no cover ...@@ -417,8 +425,6 @@ def main(): # pragma: no cover
build_cmd = (f"DOCKER_BUILDKIT=1 docker build " build_cmd = (f"DOCKER_BUILDKIT=1 docker build "
f"-t {info.tag} -f {definition_file_path} .") f"-t {info.tag} -f {definition_file_path} .")
if info.ogsdir:
build_cmd = "(cd {0} && {1})".format(ogs_version, build_cmd)
print(f"Running: {build_cmd}") print(f"Running: {build_cmd}")
subprocess.run(build_cmd, shell=True) subprocess.run(build_cmd, shell=True)
inspect_out = subprocess.check_output( inspect_out = subprocess.check_output(
......
...@@ -126,7 +126,7 @@ class Cli_Args(argparse.ArgumentParser): ...@@ -126,7 +126,7 @@ class Cli_Args(argparse.ArgumentParser):
switches_g.add_argument('--base_image', switches_g.add_argument('--base_image',
type=str, type=str,
default='ubuntu:19.10', default='ubuntu:19.10',
help='The base image.') help='The base image. (centos:8 is supported too)')
switches_g.add_argument( switches_g.add_argument(
'--compiler', '--compiler',
type=str, type=str,
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment