You have two options for creating a new VRE project based on datalabs-docker-images
: you can either FORK this project or use a FROM instruction in your Dockerfile
A FORK is ideal for projects aiming to customize the VRE with specific apt
or conda
packages. This setup allows teams to manage updates independently and merge upstream changes on their own schedule.
The Dockerfile
FROM approach is ideal for projects wanting to receive VRE updates continuously. By simply updating the VRE Docker image tag, projects can immediately integrate the latest changes and enhancements.
Forking allows you to take full advantage of the ONBUILD
instructions defined in the base-image
, enabling seamless customization.
To select the most suitable image to modify for your needs, you need to review :
- The list of Python packages in packages.txt
- The system packages in apt.txt
- Any scripts or additional resources in the resources directory.
This will help you identify the image with dependencies closest to your requirements.
To facilitate upstream merging of the fork, rename any directories you don’t plan to use by adding a dot (.)
before the folder name.
However, do not rename the folder if you intend to build the base image locally and not pull from Dockerhub.
-
Fork the Project Click on the "Fork" button on GitHub and follow the prompts to create your forked project.
-
Make Specific Modifications Depending on your needs, you can modify several components:
- To add Python packages: Update the
environment.yml
file. - To add apt packages: Edit the
apt.txt
file. - To install additional applications: Create an
install.sh
script and place it underresources/<application-name>/
. - To add startup scripts for the VRE: Create a shell script named
start-notebook-<name>.sh
, and move it to/usr/local/bin/
within yourinstall.sh
script:
- To add Python packages: Update the
#Example
cp resources/folder/start-notebook-example.sh /usr/local/bin/
chmod +x /usr/local/bin/start-notebook-example.sh
- Build the Project
Use the make
command to build the image
#Example with base-notebook
make base-notebook
Then to run this image, run this command :
docker run -it --rm -p 8888:8888 cnes/base-notebook:master jupyter lab --ip 0.0.0.0 --allow-root --no-browser
To keep your fork updated with the original project:
- Add the upstream remote:
git remote add upstream git@github.com:CNES/datalabs-docker-images.git
- Fetch the latest branches from the upstream repository:
git fetch upstream
- Switch to your main branch:
git checkout master
- Merge changes from upstream into your main branch:
git merge upstream/master
- Resolve any conflicts (if necessary), then complete the merge:
git merge --continue
If you prefer not to fork, you can create a custom Dockerfile by extending an existing image using the FROM
instruction.
FROM cnes/base-notebook:<image-tag>
You can then add any specific packages, configurations, or scripts by modifying the Dockerfile as needed.
Build your Dockerfile with the following command:
docker build -t <name-of-the-image>:<tag> .