Skip to content

Latest commit

 

History

History

docker

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Ignition Gazebo Dockerfiles

This directory contains a few Dockerfiles and supporting scripts. See each section below for usage information about

  1. Dockerfile.ignition
  2. Dockerfile.nightly

Build Ignition Gazebo Using Nightly Debians

This section describes how to build and run a docker image based on nightly builds of downstream Ignition libraries. The Docker image will use the Ignition Gazebo code found in the current source tree.

Requirements

  1. Install Docker

  2. Optional: Install NVidia Docker

    Nvidia docker will be needed if you plan to run the GUI and/or sensors after the Docker image is built.

Steps

  1. Change the root directory of the Ignition Gazebo source tree. If you are currently in the docker subdirectory:

    cd ..
    
  2. Build the ign-gazebo:base image.

    docker build . -f ./docker/Dockerfile.base -t ign-gazebo:base
    
  3. Build the nightly docker image.

    docker build . -f ./docker/Dockerfile.nightly -t ign-gazebo:nightly
    
  4. Run the docker image with a bash shell.

    docker run -it ign-gazebo:nightly /bin/bash
    
  5. Alternatively, you can directly run Ignition Gazebo using

    ./docker/run.bash ign-gazebo:nightly ign-gazebo-server -v 4
    

Ignition Gazebo Using Debians In Docker

This section describes how to build and run a docker image of an Ignition distribution using debians.

Requirements

  1. Install Docker

  2. Install NVidia Docker

Steps

  1. Build a docker image using the build.bash command. The first argument must be the name of the Ignition distribution. For example, to build an image of Ignition Blueprint:

    ./build.bash ignition-blueprint ./Dockerfile.ignition
    
  2. Run the docker image using run.bash, and pass in the name of the docker image (first argument to the build.bash script).

    ./run.bash ignition-blueprint
    
  3. You can pass arguments to Ignition Gazebo by appending them the run.bash command. For example, to load the shapes.sdf file:

    ./run.bash ignition-blueprint -f shapes.sdf
    

Appendix

Here you'll find general information, such as installation of Docker and how to use Nvidia with Docker.

Install Docker

Docker has two available versions: Community Edition (CE) and Enterprise Edition (EE). In this tutorial, we'll install the CE version.

  1. Remove old versions of Docker (if installed):

    sudo apt-get remove docker docker-engine docker.io
    
  2. Install dependencies and keys.

     sudo apt install curl apt-transport-https ca-certificates curl software-properties-common
    
     # Add the official GPG key of Docker
     curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
    
  3. Setup Docker using 1 of the two options below.

    1. Ubuntu Bionic users

       sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) edge"
      
    2. Everyone else.

       sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"
      
  4. Install Docker

     sudo apt-get update && sudo apt-get install docker-ce
    
  5. Check your Docker installation:

     sudo docker run hello-world
    
  6. You should see the message Hello from Docker! confirming that your installation was successfully completed.

Install Nvidia Docker

  1. Remove old versions of Nvidia Docker:

     docker volume ls -q -f driver=nvidia-docker | xargs -r -I{} -n1 docker ps -q -a -f volume={} | xargs -r docker rm -f
     sudo apt-get purge -y nvidia-docker
    
  2. Setup the Nvidia Docker repository.

     curl -s -L https://nvidia.github.io/nvidia-docker/gpgkey | sudo apt-key add -
     distribution=$(. /etc/os-release;echo $ID$VERSION_ID)
     curl -s -L https://nvidia.github.io/nvidia-docker/$distribution/nvidia-docker.list | sudo tee /etc/apt/sources.list.d/nvidia-docker.list
     sudo apt-get update
    
  3. Install Nvidia Docker (version 2):

     sudo apt-get install -y nvidia-docker2
    
  4. Restart the Docker daemon

     sudo service docker restart
    
  5. Verify the installation:

     docker run --runtime=nvidia --rm nvidia/cuda nvidia-smi
    

    This command should print your GPU information, for example:

+-----------------------------------------------------------------------------+
| NVIDIA-SMI 390.116                Driver Version: 390.116                   |
|-------------------------------+----------------------+----------------------+
| GPU  Name        Persistence-M| Bus-Id        Disp.A | Volatile Uncorr. ECC |
| Fan  Temp  Perf  Pwr:Usage/Cap|         Memory-Usage | GPU-Util  Compute M. |
|===============================+======================+======================|
|   0  GeForce GTX 960     Off  | 00000000:01:00.0  On |                  N/A |
|  0%   51C    P5    12W / 160W |    775MiB /  2000MiB |      1%      Default |
+-------------------------------+----------------------+----------------------+

+-----------------------------------------------------------------------------+
| Processes:                                                       GPU Memory |
|  GPU       PID   Type   Process name                             Usage      |
|=============================================================================|
+-----------------------------------------------------------------------------+