Provided by: devscripts_2.25.5_all bug

NAME

       deb2apptainer - Build a Singularity/Apptainer image with given Debian packages

SYNOPSIS

       deb2apptainer  [-hB][-c  CMD][-f  FROM][-n  NAME][-o  DIR][-p  deb2singularity  [-hB][-c CMD][-f FROM][-n
       NAME][-o DIR][-p PRE_SCRIPT][-s POST_SCRIPT] packages

DESCRIPTION

       deb2apptainer is a simple script which takes as input a list of Debian packages and  generates  automati‐
       cally  a  Singularity/Apptainer  container  including  these  packages.  A set of freedesktop.org desktop
       launchers are also generated based on the .desktop and icon files found in the packages.  In addition,  a
       desktop launcher is created to start the container in a Terminal.

       This tool is suited for deploying applications as containers, as well as for testing Debian packages in a
       sandbox.

OPTIONS

       -B     do  NOT  build the image (default is to build).  A build script is generated in the DIR target di‐
              rectory.

       -c EXEC
              Command to run in the container (default to /bin/bash).

       -f FROM
              Distribution is to be used (default to debian:stable).

       -h     Show this help

       -n NAME
              Name of the image (default is built from the package list).

       -o DIR Use given directory DIR for the build (default is in /tmp).

       -p PRE_SCRIPT
              Execute the given script PRE_SCRIPT before packages install.

       -s POST_SCRIPT
              Execute the given script POST_SCRIPT after packages install.

       packages
              The package list can be any Debian package, as well as local .deb files.

FILES

       • DIR/README

       • DIR/image.def

       • DIR/image.sif

       • DIR/launchers/

       • DIR/icons/

       • DIR/build

       • DIR/start

NOTES

       You obviously require to have apptainer installed.

       Get the Debian package at: - https://apptainer.org/docs/admin/main/installation.html#install-debian-pack‐
       ages

       Usual commands typically used to handle Apptainer/Singularity containers are:

       build  apptainer build image.sif

       run    apptainer run image.sif apptainer run –nv image.sif # with NVIDIA GPU pass-through

       info   apptainer inspect image.sif

       header apptainer sif header image.sif

       data   apptainer sif list image.sif

EXAMPLES

       Create a Singularity/Apptainer container with package x11-apps in directory /tmp/xeyes, and launch xeyes:

       • deb2apptainer -o /tmp/xeyes x11-apps

       • /tmp/xeyes/start xeyes

         A Desktop launcher is created as /tmp/xeyes/launchers/x11-apps-terminal.desktop

       Create a Singularity/Apptainer container with x11-apps and meshlab
         deb2apptainer x11-apps meshlab

       Create a Singularity/Apptainer container making sure software channels are active:

       • echo “sed -i `s/main/main contrib non-free/g' /etc/apt/sources.list” > pre.sh

       • deb2apptainer -p pre.sh x11-apps

       Create a Singularity/Apptainer container based on specific Debian version, and make use of the GPU:

       • echo “echo `deb http://deb.debian.org/debian bullseye main contrib non-free' >>  /etc/apt/sources.list”
         > pre-script.sh

       • deb2apptainer    -n    pyhst2   -f   debian:bullseye   -p   pre-script.sh   -o   /tmp/apptainer-pyhst2/
         python3-pyhst2-cuda nvidia-smi nvidia-cuda-toolkit

       • apptainer run –nv /tmp/apptainer-pyhst2/pyhst2.sif nvidia-smi ```

AUTHORS

       Emmanuel Farhi (emmanuel.farhi@synchrotron-soleil.fr)

SEE ALSO

       deb2docker(1), distrobox-create(1), distrobox-enter(1), docker(1), apptainer(1)

AUTHORS

       Emmanuel Farhi.

                                                  February 2024                                 DEB2APPTAINER(1)