Docker Guide#

Caution

Due to the dependency on Isaac Sim docker image, by running this container you are implicitly agreeing to the NVIDIA Omniverse EULA. If you do not agree to the EULA, do not run this container.

Setup Instructions#

Note

The following steps are taken from the NVIDIA Omniverse Isaac Sim documentation on container installation. They have been added here for the sake of completeness.

Docker and Docker Compose#

We have tested the container using Docker Engine version 26.0.0 and Docker Compose version 2.25.0 We recommend using these versions or newer.

  • To install Docker, please follow the instructions for your operating system on the Docker website.

  • To install Docker Compose, please follow the instructions for your operating system on the docker compose page.

  • Follow the post-installation steps for Docker on the post-installation steps page. These steps allow you to run Docker without using sudo.

  • To build and run GPU-accelerated containers, you also need install the NVIDIA Container Toolkit. Please follow the instructions on the Container Toolkit website for installation steps.

Note

Due to limitations with snap, please make sure the Isaac Lab directory is placed under the /home directory tree when using docker.

Obtaining the Isaac Sim Container#

  • Get access to the Isaac Sim container by joining the NVIDIA Developer Program credentials.

  • Generate your NGC API key to access locked container images from NVIDIA GPU Cloud (NGC).

    • This step requires you to create an NGC account if you do not already have one.

    • You would also need to install the NGC CLI to perform operations from the command line.

    • Once you have your generated API key and have installed the NGC CLI, you need to log in to NGC from the terminal.

      ngc config set
      
  • Use the command line to pull the Isaac Sim container image from NGC.

    docker login nvcr.io
    
    • For the username, enter $oauthtoken exactly as shown. It is a special username that is used to authenticate with NGC.

      Username: $oauthtoken
      Password: <Your NGC API Key>
      

Directory Organization#

The root of the Isaac Lab repository contains the docker directory that has various files and scripts needed to run Isaac Lab inside a Docker container. A subset of these are summarized below:

  • Dockerfile.base: Defines the base Isaac Lab image by overlaying its dependencies onto the Isaac Sim Docker image. Dockerfiles which end with something else, (i.e. Dockerfile.ros2) build an image extension.

  • docker-compose.yaml: Creates mounts to allow direct editing of Isaac Lab code from the host machine that runs the container. It also creates several named volumes such as isaac-cache-kit to store frequently re-used resources compiled by Isaac Sim, such as shaders, and to retain logs, data, and documents.

  • .env.base: Stores environment variables required for the base build process and the container itself. .env files which end with something else (i.e. .env.ros2) define these for image extension.

  • container.py: A utility script that interfaces with tools in utils to configure and build the image, and run and interact with the container.

Running the Container#

Note

The docker container copies all the files from the repository into the container at the location /workspace/isaaclab at build time. This means that any changes made to the files in the container would not normally be reflected in the repository after the image has been built, i.e. after ./container.py start is run.

For a faster development cycle, we mount the following directories in the Isaac Lab repository into the container so that you can edit their files from the host machine:

  • IsaacLab/source: This is the directory that contains the Isaac Lab source code.

  • IsaacLab/docs: This is the directory that contains the source code for Isaac Lab documentation. This is overlaid except for the _build subdirectory where build artifacts are stored.

The script container.py parallels basic docker compose commands. Each can accept an image extension argument, or else they will default to the base image extension. These commands are:

  • start: This builds the image and brings up the container in detached mode (i.e. in the background).

  • enter: This begins a new bash process in an existing Isaac Lab container, and which can be exited without bringing down the container.

  • config: This outputs the compose.yaml which would be result from the inputs given to container.py start. This command is useful for debugging a compose configuration.

  • copy: This copies the logs, data_storage and docs/_build artifacts, from the isaac-lab-logs, isaac-lab-data and isaac-lab-docs volumes respectively, to the docker/artifacts directory. These artifacts persist between docker container instances and are shared between image extensions.

  • stop: This brings down the container and removes it.

The following shows how to launch the container in a detached state and enter it:

# Launch the container in detached mode
# We don't pass an image extension arg, so it defaults to 'base'
./docker/container.py start

# If we want to add .env or .yaml files to customize our compose config,
# we can simply specify them in the same manner as the compose cli
# ./docker/container.py start --file my-compose.yaml --env-file .env.my-vars

# Enter the container
# We pass 'base' explicitly, but if we hadn't it would default to 'base'
./docker/container.py enter base

To copy files from the base container to the host machine, you can use the following command:

# Copy the file /workspace/isaaclab/logs to the current directory
docker cp isaac-lab-base:/workspace/isaaclab/logs .

The script container.py provides a wrapper around this command to copy the logs , data_storage and docs/_build directories to the docker/artifacts directory. This is useful for copying the logs, data and documentation:

# stop the container
./docker/container.py stop

X11 forwarding#

The container supports X11 forwarding, which allows the user to run GUI applications from the container and display them on the host machine.

The first time a container is started with ./docker/container.py start, the script prompts the user whether to activate X11 forwarding. This will create a file at docker/.container.cfg to store the user’s choice for future runs.

If you want to change the choice, you can set the parameter X11_FORWARDING_ENABLED to ‘0’ or ‘1’ in the docker/.container.cfg file to disable or enable X11 forwarding, respectively. After that, you need to re-build the container by running ./docker/container.py start. The rebuilding process ensures that the changes are applied to the container. Otherwise, the changes will not take effect.

After the container is started, you can enter the container and run GUI applications from it with X11 forwarding enabled. The display will be forwarded to the host machine.

Python Interpreter#

The container uses the Python interpreter provided by Isaac Sim. This interpreter is located at /isaac-sim/python.sh. We set aliases inside the container to make it easier to run the Python interpreter. You can use the following commands to run the Python interpreter:

# Run the Python interpreter -> points to /isaac-sim/python.sh
python

Understanding the mounted volumes#

The docker-compose.yaml file creates several named volumes that are mounted to the container. These are summarized below:

Volume Name

Description

Container Path

isaac-cache-kit

Stores cached Kit resources

/isaac-sim/kit/cache

isaac-cache-ov

Stores cached OV resources

/root/.cache/ov

isaac-cache-pip

Stores cached pip resources

/root/.cache/pip

isaac-cache-gl

Stores cached GLCache resources

/root/.cache/nvidia/GLCache

isaac-cache-compute

Stores cached compute resources

/root/.nv/ComputeCache

isaac-logs

Stores logs generated by Omniverse

/root/.nvidia-omniverse/logs

isaac-carb-logs

Stores logs generated by carb

/isaac-sim/kit/logs/Kit/Isaac-Sim

isaac-data

Stores data generated by Omniverse

/root/.local/share/ov/data

isaac-docs

Stores documents generated by Omniverse

/root/Documents

isaac-lab-docs

Stores documentation of Isaac Lab when built inside the container

/workspace/isaaclab/docs/_build

isaac-lab-logs

Stores logs generated by Isaac Lab workflows when run inside the container

/workspace/isaaclab/logs

isaac-lab-data

Stores whatever data users may want to preserve between container runs

/workspace/isaaclab/data_storage

To view the contents of these volumes, you can use the following command:

# list all volumes
docker volume ls
# inspect a specific volume, e.g. isaac-cache-kit
docker volume inspect isaac-cache-kit

Isaac Lab Image Extensions#

The produced image depends upon the arguments passed to container.py start and container.py stop. These commands accept an image extension parameter as an additional argument. If no argument is passed, then this parameter defaults to base. Currently, the only valid values are (base, ros2). Only one image extension can be passed at a time. The produced container will be named isaac-lab-${profile}, where ${profile} is the image extension name.

# start base by default
./docker/container.py start
# stop base explicitly
./docker/container.py stop base
# start ros2 container
./docker/container.py start ros2
# stop ros2 container
./docker/container.py stop ros2

The passed image extension argument will build the image defined in Dockerfile.${image_extension}, with the corresponding profile in the docker-compose.yaml and the envars from .env.${image_extension} in addition to the .env.base, if any.

ROS2 Image Extension#

In Dockerfile.ros2, the container installs ROS2 Humble via an apt package, and it is sourced in the .bashrc. The exact version is specified by the variable ROS_APT_PACKAGE in the .env.ros2 file, defaulting to ros-base. Other relevant ROS2 variables are also specified in the .env.ros2 file, including variables defining the various middleware options.

The container defaults to FastRTPS, but CylconeDDS is also supported. Each of these middlewares can be tuned using their corresponding .xml files under docker/.ros.

Parameters for ROS2 Image Extension
###
# ROS2 specific settings
###
# Set the version of the ROS2 apt package to install (ros-base, desktop, desktop-full)
ROS2_APT_PACKAGE=ros-base
# Set ROS2 middleware implementation to use (e.g. rmw_fastrtps_cpp, rmw_cyclonedds_cpp)
RMW_IMPLEMENTATION=rmw_fastrtps_cpp
# Path to fastdds.xml file to use (only needed when using fastdds)
FASTRTPS_DEFAULT_PROFILES_FILE=${DOCKER_USER_HOME}/.ros/fastdds.xml
# Path to cyclonedds.xml file to use (only needed when using cyclonedds)
CYCLONEDDS_URI=${DOCKER_USER_HOME}/.ros/cyclonedds.xml

Known Issues#

WebRTC Streaming#

When streaming the GUI from Isaac Sim, there are several streaming clients available. There is a known issue when attempting to use WebRTC streaming client on Google Chrome and Safari while running Isaac Sim inside a container. To avoid this problem, we suggest using the Native Streaming Client or using the Mozilla Firefox browser on which WebRTC works.

Streaming is the only supported method for visualizing the Isaac GUI from within the container. The Omniverse Streaming Client is freely available from the Omniverse app, and is easy to use. The other streaming methods similarly require only a web browser. If users want to use X11 forwarding in order to have the apps behave as local GUI windows, they can uncomment the relevant portions in docker-compose.yaml.