/docker-stacks

Ready-to-run Docker images containing Openalea applications

Primary LanguageDockerfile

Openalea Docker Images

This is an ongoing project. This README is subject to modification, as well as the whole behaviour of the package.


This projects aims at publishing ready to use images of OpenAlea stacks in a reproducible computing environment. These images are built on top of the Ubuntu operating system using conda environments. It is heavily inspeired by existing openalea docker stacks and pangeo-docker-images projects.

Images are meant to be hosted on DockerHub.

So far, here is a list of images created. You can easily add your creation of images and propose to include it in this project (cf. steps bellow):

Image Description
base-openalea Foundational Dockerfile for builds. Not intended for use
openalea-notebook Functional image with basic Openalea packages + advanced widgets for interactive visualization using lpy and PlanGL
strawberry-openalea openalea-notebook + strawberry package and associated interactive visualization tools
hydroroot-openalea openalea-notebook + hydroroot package and associated interactive visualization tools
fullstack-openalea All the packages release en 05-2022 on the openalea3 anaconda channel + advanced widgets for interactive visualization used in openalea-widgets-notebook

Click on the image name in the table above for a current list of installed packages and versions

How to launch Jupyterlab locally with one of these images

At launching one image, a conda environments named openalea is automaticaly loaded with all packages already installed. You can directly launch a jupyter interface with:

docker run -it --rm -p 8888:8888 openalea/notebook-openalea:latest jupyter lab --ip 0.0.0.0

or do it in two steps, 1) launching a bash session inside the container, 2) lauch a jupyter lab:

docker run -it --rm -p 8888:8888 openalea/notebook-openalea:latest /bin/bash

jupyter lab --ip='*' --port=8888 --no-browser

To access files from your local hard drive from within the Docker Jupyterlab, you need to use a Docker volume mount. The following command will mount your home directory in the docker container and launch the Jupyterlab from there.

docker run -it --rm --volume $HOME:$HOME -p 8888:8888 openalea/notebook-openalea:latest jupyter lab --ip 0.0.0.0 $HOME

How to build images

Localy

To build images localy, you'll need Conda installed.

# create a fork of this repo and clone it locally
git clone https://cirad.gitlab/openalea/openalea-docker-images
cd openalea-docker-images
# Install conda-lock
conda install conda-lock

Edit any environment.yml to change packages installed using conda/mamba, or requirements.txt to change the list of packages installed using pip, or even sources.txt for packages that need to be installed from sources cloning the .git repository and using setup.py !

Then make notebook-widgets-openalea (for example) allows to build and test the image. See the Makefile for specific commands that are run.

To add your own image:

  1. create a new directory at the base of the project
mkdir fancy-image-openalea
cd fancy-image-openalea
  1. add the relevant apt.txt, environment.yml, requirements.txt, sources.txt to install linux utilities, tools and python libraries via conda, python libraries via pip, python libraries via git repositories, respectively. Use can use as templates the files available in strawberry-openalea for example.
vi apt.txt
vi environment.yml
vi requirements.txt
vi sources.txt
  1. Create a Dockerfile Create your own Dockerfile. The mandatory line is the first one
FROM openalea/base-openalea:latest

This will install all the libraries and packages provided in the step before. If additional operations are necessary (like copying example files or data), this has to be done here.

  1. Modify the Makefile Simply add you new rule to compile the new image following the rule used for existing images.

Continous integration

⚠️ Deprecated. Only valid for Gitlab-CI. Need to update for github-actions Continous integration has been implemented for Gitlab, cf. the original gitlab page of the project. Every time you push a commit on this project, it will first build and upload to dockerhub the base-image, then build and upload all the other images on top of it, and finaly test all the images. You need to register Gitlab-CI-CD variables to login to your dockerhub account (CI_REGISTRY_USER and CI_REGISTRY_PASSWORD).

If you want to add your image, when you're done creating the folder describing your new image (cf. steps 1 to 3 in the previous section), you simply need to add your image name in the parallel:matrix:IMAGE_NAME section of .gitlab-ci.yml file, both for building stage et testing stage.

Launching OpenAlea and Visualea in Docker

Python2 image :

You need a lot of options in the docker run since the container run a X server (they are indicated in the README of the file). Additionally, there is no need to open the ports since it just open an app.

pip install docker
docker pull openalea/python2
docker run -it --env QT_X11_NO_MITSHM=1 -e DISPLAY=$DISPLAY -v /tmp/.X11-unix:/tmp/.X11-unix --volume=$PWD:/home/User001:rw openalea/python2

Mac users

Preliminary steps are necessary (cf. https://cntnr.io/running-guis-with-docker-on-mac-os-x-a14df6a76efc)

# retrive IP address from host OS
ipAdress=`ifconfig | grep inet | grep broadcast | awk '{print $2}' | tail -1`

# deal with the socat
socat TCP-LISTEN:6000,reuseaddr,fork UNIX-CLIENT:\"$DISPLAY\" &

docker run -it --rm --env="DISPLAY=${ipAdress}:0" --volume=$PWD:/home/User001:rw openalea/python2:latest

# Kill socat
lsof -n -i | grep 6000 | grep IPv6 | awk '{print $2}' | xargs kill -9

Windows users

  • Install WSL2, Docker and an X server
    • Install WSL2
      • Launch PowerShell as an administratorr (right-clic) wsl --install -d Ubuntu

      • Check which Linux distribution is installed and which version (2 is mandatory): wsl -l -v
        If necessary:
        wsl --set-default-version 2
        wsl --setdefault Ubuntu

        Then launch Ubuntu and into the Ubuntu terminal:

      • update sudo apt update && sudo apt upgrade -y

    • Install docker
      • Download and install Docker
      • During installation process, make sure you need WSL2 integration.
      • In Docker Desktop -> Parameters -> Resources -> WSL integration -> Enable integration with additional distros and enable for Ubuntu
    • Install an X-Server
  • Use a graphical app in a Docker container
    • !!! Do this only once !!! You have to activate the graphical display for your container, so first propagate the i.p. adress to the DISPLAY environment viariable:
      • Launch Ubuntu
      • In the the .bashrc file, add the following lines:
        export DISPLAY=$(route.exe print | grep 0.0.0.0 | head -1 | awk '{print $4}'):0.0
        export LIBGL_ALWAYS_INDIRECT=1
        
    • Routine for launching your graphical app
      • Launch Vcxsrv (X-Launch icon on desktop or in App bar): Multiple Windows -> Start no client -> Enable Disable access cpontrol (you can eventualy save this configuration for later).

      • Launch Docker Desktop

      • Lancer Ubuntu

      • Now everything should be ok for a graphical display with your app in a container. Let's make a test. In your Ubuntu terminal: docker run --rm -it -e DISPLAY fr3nd/xeyes and you should see 2 eyes: congrats !

        That's it.... you should be able to run any graphical application embedded in a docker. Let's try some more serious stuff:
        docker run --rm -it -e DISPLAY openalea/python2

    • What about my data ?
      • In WSL / Ubuntu, C: and D: drives are located in /mnt/c and /mnt/d respectively.
      • If you want to access your data into your container app, you have to bind mount the directories you want to access. Let's say you want to run the openalea/python2 container with full access to both your C: and D: drives:
        • run docker run --rm -it -e DISPLAY -v /mnt/c:/home/User001/c -v /mnt/d:/home/User001/d openalea/python2
        • you should see your directories c and d with all your data available on your home directory inside the container (home/User001 is the home directory for the container), and these directories can be read / modified / written
        • if you notice some performance issues, we recommand to either 1) bind mount smaller directories (i.e. not the full /mnt/c or /mnt/d drives, but only usefull subparts of these) or 2) if your workflow allows this, you can create a docker volume
      • to ease the launch of your app, we recommand to create an alias in your ./bashrc file: alias openalea=docker run --rm -it -e DISPLAY -v /mnt/c:/home/User001/c -v /mnt/d:/home/User001/d openalea/python2. Then in your terminal you just have to type openalea to launch the container, access your data and have the graphical display enabled.

Contribute

If you created an image of any Openalea package or package list, you are welcome to submit a pull request containing a summary of all depedancies, the version of the build, and wich packages are concerned. We will also need a image on Docker Hub to test it.