Skip to content

Dynamics-Learning-Workshop/docker_practice

 
 

Repository files navigation

Docker Practice of AIRO Lab

Abstract

I blabbered a lot in this README.md below, to save you some time, here's a short summary:

  1. install

    refer to this site.

  2. to build (create image)

    ./build_lala.sh
    
  3. to run (image -> container)

    ./run_lala.sh
    
  4. to run custom (custom image -> container)

    ./run_hehe.sh {image_name}
    
  5. to debug xAUTH-related error

    ./cleanup.sh
    

VOILA! Now off you go! For Docker commandline cheatsheet, please refer to here or here

Intro

With the increasing number of lab members, we are now enforcing a new practice of Docker on public computing devives, i.e., for all members that wish to use lab machines (including GPU server, UAV/UGV onboard computers, or even UUV in the future), will be required to use Docker container to run their code. The following are the reasons:

  • repeating setups for environs are no more needed.
  • clashes between libraries could be prevented.
  • it's cool.

It might be painful at first, but for the COLLECTIVE GOOD AND NEAT PRACTICE, we hope that everyone could cooperate. We have setup a docker container (not constructed with a systematical way yet it work), you can just simply do docker pull {image} and start to do a lotta shit (run ROS and stuff basically).

Below will first briefly elucidate what we have done to this poor image, and how to ssh, network sharing and visualize files; some ros packages are also included so feel free to try. This repo is in the public domain, people outside our lab are welcomed to use. Similar to many other repo of ours, we love pull requests, so please do offer suggestions!

Prerequisite

  1. Refer to this site to install.

    You can install Docker Engine by following the setup bash command. In Ubuntu, we do not really need Docker Desktop. As we are not considerate people, we will not repeat the installation process here.

  2. First either do ./build_lala.sh.

    The shell file will spit out some instruction, and just select what you want. In our supported image, we provide with/without GPU, with/without AIRO packages. Additionally, if you do not want to build from the start, you can select swift to accelerate the building time.

  3. Then, to create one container, do ./run_lala.sh.

  4. Change passcode.

    After entering the docker container, input

    echo -e "0000\n0000" | passwd root
    

    to set the root passcode.

  5. (Optional) To run more packages from us, please refer to this repo for installation.

  6. (Optional) You can refer to Dockerfile.lala to see what building arguments we put there. After the image is built, a few things could be used directly:

    tmux
    ros
    mavros
    PX4 firmware + Gazebo simulation
    ngrok
    ssh
    VScode remote (through ssh or ngrok)
    

    If you want a more detailed description of the above image, please refer to this.

  7. (Optional) If you want to use GPU programming, please run ./lala_nvidia.sh

  8. (Update) Use cleanup.sh when you encounter .XAuth... -related bug. We did not really figure out the main reason for this, but was able to work our way out by doing ./cleanup.sh.

What you should test.

You need to do something now!

  1. Check container status

    Check whether the container is up by

    docker container ps -a
    

    There should be a container listed as:

    alt text

  2. Check visualization

    Run xclock #install x11-apps and see whether there is a tiny little clock appears like this:

    alt text.

    The time might not be right, but it is not really important at this stage.

  3. Check hardware connection

    In the docker run file, we have specified -v/dev:/dev, which gives basically all USB, video and so on... access to container.

    The easiest way to confirm the connection is to run rqt_image_view to check the message.

    You can also try to do ls /dev/tty to check whether the ttl serial is connected.

  4. Check external connection

    First download telnet, it allows you to check the connection with a specified port.

    Do the following to check IP_ADDRESS.

    Note That IP_ADDRESS here could either be:

    1. localhost(127.0.0.1)
    2. LAN Address
    3. WAN third party URL
    ifconfig
    

    alt text

    Then, outside your container, do

    sudo apt install telnet
    telnet {IP_ADDRESS} 6666
    

    You should get something like below which shows:

    Trying {IP_ADDRESS}
    Connected to {IP_ADDRESS}
    

    alt text Within the image, LHS shows container, whilst RHS shows telnet connection status.

  5. So far so good? Now, on any laptop within the same local network, try to do:

    ssh root@{IP_ADDRESS} -p 6666
    # passcode 0000
    

    You should be able to access the container by now. Now, you own a tiny OS within your OS, isn't it interesting?

  6. On VScode, access the files inside the container just as an usual ssh server. If you are from AIRO-lab, we strongly you to go through this tutorial here.

  7. As mentioned above, if you want to use ngrok to remote ssh from anywhere, please do the following:

    • If you do not have a ngrok account, please register one.

    • After getting one, please do ngrok config add-authtoken <your_token>

    • At the entering file location, do ./ngrok.

    • Check the forwarding line , and get the port number; on another random machine (within/out LAN), do

      ssh root@0.tcp.ap.ngrok.io -p {port_number}

      alt text

    • Also try it in vscode, and see whether you are able to visualize all the code.

    • Voila! With all these, you should be able to code anywhere and anytime.

Side Note

  1. Basically, you should be able to use it as a normal ubuntu ROS environment, just within a sandbox. Again, the main reason for us to use this is that it allows us to setup enviroment on a new machine with only one commandline: i.e., docker image pull pattylo/airo_ros_noetic:lala.
  2. Basically image is like a template of a container. Bear this in mind.
  3. As you will be launching a lot of terminals within a container, it will be stupid to do docker exec all the time, and thus, tmux is recommended. Some very preliminary notes are mentioned here.
  4. Some useful docker commandline for your reference:
    docker image pull {image_name} # pull an image
    docker run -blah_blah {image_name} # run an image and create a container
    docker container ps -a # list all container
    docker image ls # list all image
    
    docker start {container_name} # start container
    docker attach {container_name} # attach to a container, namely, get inside the container
    docker exec -it {container_name} /bin/bash # attach to the same container without echoing the same commandline
    ctrl + p then ctrl + q to detach from docker
    exit # exit container
    
    docker commit {container_name} {new_image_name} 
    # create an image after you modify a container
    # this could become your new template
    
    docker rm {container_name}
    docker rmi {image_name}
    
    docker tag {container_name} {username}/{remote_image_name}
    docker push {username}/{remote_image_name}
    # basically allow you to publish your image
    
  5. The learning curve of Docker is not steep. We are not very experienced, but were able to pick it up within a week. Just try to search more learning material lah! Have fun Dockering!

Shoutout

We would like to give a shoutout to the Larics Lab for inspiring us to adopt this practice. Go follow them! They are doing some solid engineering work there!

Maintainer

pattylo @ AIRO-LAB @ RCUAS, HKPolyU

About

A docker practice for y'all :)

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Shell 100.0%