How to Set Up Docker on Ubuntu

This guide will show you how to set up Docker in Ubuntu. Not only that! You will also see some useful examples and commands.

YouTube player

What is Docker?

Docker uses virtualization technology which in turn makes developing and deploying containerized applications a breeze! Virtualization allows the container to be deployed on any machine without any compatibility issues. So it makes your software simple to develop, deploy, use and maintain.

Docker Containers are, however, different from a typical virtual machine in that they act as micro-services, each with specific jobs. Each Docker container runs the operating system on isolated CPU processes, memory, and network resources. Because of this, you can be easily added, remove, start and stop it again without affecting the host operating system. Containers usually run one specific task such as MySQL database or Node.js application and network it together to scale them.

Unlike virtual machines, resources are shared directly with hosts. This allows you to run many docker containers. In addition, Docker uses less disk space as it can reuse files using the layered file system.

Requirements

Heads up! You will require the following items for you to proceed:

  • A server running Ubuntu 18.04 or 20.04
  • A root password is configured on your server

Install the required dependencies

First, you will need to install some dependencies need by Docker in your server. You can install all these dependencies by running the following command:

apt-get install apt-transport-https ca-certificates curl gnupg2 software-properties-common -y

After installing all the required packages, you can proceed to install Docker.

Setup Docker

By default, the latest version of Docker is not available in the Ubuntu default repository. So it is a good idea to install Docker from the official docker repository. But, first, let’s see how to set up Docker on Ubuntu.

First, download and add the Docker GPG key with the following command:

curl -fsSL https://download.docker.com/linux/ubuntu/gpg | apt-key add -

Next, add the Docker repository using the APT command mentioned below. Finally, you can set your architecture to x86_64, amd64, armhf, or arm64.

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

Once the repository is added, update the repository and install the latest version of the Docker with the following command:

apt-get update -y
apt-get install docker-ce docker-ce-cli containerd.io -y

Now, you can verify the status of the Docker with the following command:

systemctl status docker

You should see the following output once Docker has been setup:

● docker.service - Docker Application Container Engine
   Loaded: loaded (/lib/systemd/system/docker.service; enabled; vendor preset: enabled)
   Active: active (running) since Tue 2020-06-16 09:25:58 AEST; 2 months 22 days ago
     Docs: https://docs.docker.com
 Main PID: 3353 (dockerd)
    Tasks: 36
   Memory: 74.4M
   CGroup: /system.slice/docker.service
           ├─3353 /usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock

How to use Docker?

Now that you have set up Docker on Ubuntu let’s see how you use it.

The basic syntax of the Docker command is shown below:

docker [option] [command] [arguments]

You can list all available options with docker by running the following command:

docker

You should see the complete list of docker subcommands in the following output:

Usage:	docker [OPTIONS] COMMAND

A self-sufficient runtime for containers

Options:
      --config string      Location of client config files (default "/home/anthony/.docker")
  -c, --context string     Name of the context to use to connect to the daemon (overrides DOCKER_HOST env var and default context set with "docker
                           context use")
  -D, --debug              Enable debug mode
  -H, --host list          Daemon socket(s) to connect to
  -l, --log-level string   Set the logging level ("debug"|"info"|"warn"|"error"|"fatal") (default "info")
      --tls                Use TLS; implied by --tlsverify
      --tlscacert string   Trust certs signed only by this CA (default "/home/anthony/.docker/ca.pem")
      --tlscert string     Path to TLS certificate file (default "/home/anthony/.docker/cert.pem")
      --tlskey string      Path to TLS key file (default "/home/anthony/.docker/key.pem")
      --tlsverify          Use TLS and verify the remote
  -v, --version            Print version information and quit

Management Commands:
  builder     Manage builds
  config      Manage Docker configs
  container   Manage containers
  context     Manage contexts
  engine      Manage the docker engine
  image       Manage images
  network     Manage networks
  node        Manage Swarm nodes
  plugin      Manage plugins
  secret      Manage Docker secrets
  service     Manage services
  stack       Manage Docker stacks
  swarm       Manage Swarm
  system      Manage Docker
  trust       Manage trust on Docker images
  volume      Manage volumes

Commands:
  attach      Attach local standard input, output, and error streams to a running container
  build       Build an image from a Dockerfile
  commit      Create a new image from a container's changes
  cp          Copy files/folders between a container and the local filesystem
  create      Create a new container
  deploy      Deploy a new stack or update an existing stack
  diff        Inspect changes to files or directories on a container's filesystem
  events      Get real time events from the server
  exec        Run a command in a running container
  export      Export a container's filesystem as a tar archive
  history     Show the history of an image
  images      List images
  import      Import the contents from a tarball to create a filesystem image
  info        Display system-wide information
  inspect     Return low-level information on Docker objects
  kill        Kill one or more running containers
  load        Load an image from a tar archive or STDIN
  login       Log in to a Docker registry
  logout      Log out from a Docker registry
  logs        Fetch the logs of a container
  pause       Pause all processes within one or more containers
  port        List port mappings or a specific mapping for the container
  ps          List containers
  pull        Pull an image or a repository from a registry
  push        Push an image or a repository to a registry
  rename      Rename a container
  restart     Restart one or more containers
  rm          Remove one or more containers
  rmi         Remove one or more images
  run         Run a command in a new container
  save        Save one or more images to a tar archive (streamed to STDOUT by default)
  search      Search the Docker Hub for images
  start       Start one or more stopped containers
  stats       Display a live stream of container(s) resource usage statistics
  stop        Stop one or more running containers
  tag         Create a tag TARGET_IMAGE that refers to SOURCE_IMAGE
  top         Display the running processes of a container
  unpause     Unpause all processes within one or more containers
  update      Update configuration of one or more containers
  version     Show the Docker version information
  wait        Block until one or more containers stop, then print their exit codes

Run 'docker COMMAND --help' for more information on a command.

Run ‘docker COMMAND –help’ for more information on a command.

You can also display more information about Docker using the following command:

docker info

You should see the following output:

Client:
 Debug Mode: false

Server:
 Containers: 2
  Running: 1
  Paused: 0
  Stopped: 1
 Images: 9
 Server Version: 19.03.8
 Storage Driver: zfs
  Zpool: rpool
  Zpool Health: ONLINE
  Parent Dataset: rpool/ROOT/ubuntu_yybki6/var/lib
  Space Used By Parent: 3448905728
  Space Available: 946661916672
  Parent Quota: no
  Compression: lz4
 Logging Driver: json-file
 Cgroup Driver: cgroupfs
 Plugins:
  Volume: local
  Network: bridge host ipvlan macvlan null overlay
  Log: awslogs fluentd gcplogs gelf journald json-file local logentries splunk syslog
 Swarm: inactive
 Runtimes: runc
 Default Runtime: runc
 Init Binary: docker-init
 containerd version: 7ad184331fa3e55e52b890ea95e65ba581ae3429
 runc version: dc9208a3303feef5b3839f4323d9beb36df0a9dd
 init version: fec3683
 Security Options:
  apparmor
  seccomp
   Profile: default
 Kernel Version: 5.3.0-59-generic
 Operating System: Ubuntu 19.10
 OSType: linux
 Architecture: x86_64
 CPUs: 8
 Total Memory: 7.356GiB
 Name: merlin
 ID: 5YZ2:UZF4:XECY:2HGI:ON4G:BSDU:3TQM:QOFX:MFO6:62L6:24WS:GOYN
 Docker Root Dir: /var/lib/docker
 Debug Mode: false
 Registry: https://index.docker.io/v1/
 Labels:
 Experimental: false
 Insecure Registries:
  127.0.0.0/8
 Live Restore Enabled: false

Why not run a container now that you have set up Docker? Next, we will pull and run an Nginx container.

Pull a Docker Image from the Docker Hub

Now that you have set up Docker on Ubuntu let’s see how you pull an image. A Docker image is a file built from an application’s instructions or executable version used to execute code in a Docker container. All docker images are stored in the Docker Hub registry. You can pull your desired image from the Docker Hub using the “docker pull” command.

For example, pull the Nginx image from the Docker Hub, run the following command:

docker pull nginx

This will download an Nginx image from the Docker Hub to your local system. Once the download is completed, you should see the following output:

Using default tag: latest
latest: Pulling from library/nginx
bf5952930446: Pull complete 
cb9a6de05e5a: Pull complete 
9513ea0afb93: Pull complete 
b49ea07d2e93: Pull complete 
a5e4a503d449: Pull complete 
Digest: sha256:b0ad43f7ee5edbc0effbc14645ae7055e21bc1973aee5150745632a24a752661
Status: Downloaded newer image for nginx:latest
docker.io/library/nginx:latest

You can list your downloaded image by running the following command:

docker images

You should see all the downloaded images in the following output:

REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
nginx               latest              4bb46517cac3        3 weeks ago         133MB

Run a Docker container

At this point, you have set up Docker on Ubuntu and downloaded the Nginx image from the Docker Hub. Now, you will need to run a container from the downloaded image.

There are two ways to run a container.

Run a Docker container in interactive mode

Running a docker container in interactive mode gives you interactive shell access into the container. You can do it using the switch -it as shown below:

docker run -it nginx /bin/bash

This command will bring inside the docker container as shown below:

root@2cc89e08ffb2:/#

Here, you can run any command in the container. For example, run the following command to update the package repository:

root@2cc89e08ffb2:/# apt-get update -y

You can exit from the container with the following command:

root@2cc89e08ffb2:/# exit

Run a Docker container in detached mode

You can run the docker container in detached mode or background using the -d switch. In this mode, you can run any other commands while the container is running.

You can run an Nginx container in detached mode using the following command:

docker run -it -d -p 8080:80 nginx

Once the container is started, you should see the following output:

c135e6f9cb71940d3f033c2d1b5ea21766c86ca9908e0aa21e11f88fe5839302

You can now list the running containers with the following command:

docker ps

Finally, you should see your Nginx container in the following output:

CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                  NAMES
1db0b827baa2        nginx               "/docker-entrypoint.…"   17 seconds ago      Up 15 seconds       0.0.0.0:8080->80/tcp   lucid_hofstadter

If you want to connect to your Nginx container, run the following command:

docker exec 1db0b827baa2

Where 1db0b827baa2 is the id of the Nginx container.

Run a Docker Container with Volume

Volume is used when you want to store the data on the host system and share them across all containers.

First, create a new volume directory on the host system:

mkdir /volume

Next, run the Nginx container and mount the /volume directory to the Nginx container on the /var/www/html directory.

docker run -it -d -v /volume:/var/www/html -p 8080:80 nginx

Next, connect to the Nginx container with the following command:

docker exec -it aba00ef3968b /bin/bash

Then, create a file named test.html inside /var/www/html directory:

touch /var/www/html/test.html

Now, exit from the Nginx container with the following command:

exit

Now, run the following command to list the available files in the /volume directory:

ls /volume

You should see the file named test.html, which you have created inside the Nginx container:

test.html

Copy File To and From the Docker Container

The simple and easiest way to copy a file to and from the running container is to use the “docker cp” command.

To copy a file named /etc/hosts from the host system to the Nginx container, run the following command:

docker cp /etc/hosts aba00ef3968b:/opt/

To copy a file named /etc/fstab from the Nginx container to the host system, run the following command:

docker cp aba00ef3968b:/etc/fstab /opt/

Start, Stop and Pause the Container

To stop the Nginx container, run the following command:

docker container stop aba00ef3968b

To start the Nginx container, run the following command:

docker container start aba00ef3968b

You can also pause the Nginx container using the following command:

docker container pause aba00ef3968b

To stop all running containers, run the following command:

docker container stop $(docker container ls -aq)

Remove Docker Container

To remove a container, you will need to stop it first.

For example, stop the Nginx container with the following command:

docker container stop aba00ef3968b

Next, remove the Nginx container using the following command:

docker container rm aba00ef3968b

If you want to remove all stopped containers, run the following command:

docker container rm $(docker container ls -aq)

Remove Docker Images

To remove the Docker images, list all images in your system with the following command:

docker images

You should see the following output:                                                         

REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
nginx               latest              4bb46517cac3        3 weeks ago         133MB	

Now, remove the Nginx image with the following command:

docker image rm 4bb46517cac3

You should see the following output if any container uses the image:

Error response from daemon: conflict: unable to delete 4bb46517cac3 (cannot be forced) - image is being used by running container 798c8c54736c

In this case, you will need to stop that container then remove the image.

To remove all  unused images in your system, run the following command:

docker image prune -a

You will be asked to confirm before removing the image as shown below:

WARNING! This will remove all images without at least one container associated to them.
Are you sure you want to continue? [y/N] y
Deleted Images:
untagged: nginx:latest
untagged: nginx@sha256:b0ad43f7ee5edbc0effbc14645ae7055e21bc1973aee5150745632a24a752661
deleted: sha256:4bb46517cac397bdb0bab6eba09b0e1f8e90ddd17cf99662997c3253531136f8
deleted: sha256:80b21afd8140706d5fe3b7106ae6147e192e6490b402bf2dd2df5df6dac13db8
deleted: sha256:0f04ae71e99f5ef9021b92f76bac3979e25c98d73a51d33ce76a78da6afa9f27
deleted: sha256:9a14852344d88a1fdf8297914729834521ec1c77a27e7e7e394f9c1ef9b87f9d
deleted: sha256:74299126f8099031c5bbd4774147f4ab6b0d0c3afcec774be65d4d07b956752e
deleted: sha256:d0f104dc0a1f9c744b65b23b3fd4d4d3236b4656e67f776fe13f8ad8423b955c

Total reclaimed space: 132.6MB

Wrapping up how to set up Docker on Ubuntu

In the above guide, you learned what Docker is, set up Docker, and several commands to manage the Docker container. Therefore, you should ow have basic knowledge of Docker. You can now explore docker and deploy your application in a containerized environment.

You may also be interested in

About Anto Online

Anto, a seasoned technologist with over two decades of experience, has traversed the tech landscape from Desktop Support Engineer to enterprise application consultant, specializing in AWS serverless technologies. He guides clients in leveraging serverless solutions while passionately exploring cutting-edge cloud concepts beyond his daily work. Anto's dedication to continuous learning, experimentation, and collaboration makes him a true inspiration, igniting others' interest in the transformative power of cloud computing.

View all posts by Anto Online

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.