Nikolay Grozev
Nikolay Grozev

Categories

Tags

Table of Contents

Introduction

Docker used to run “out of the box” only on Linux-based systems, but now it is available for Windows and OS X as well, without the need for third party tools. This makes it worthwhile to create a quick reference for often used docker commands and tools. This post is a cheat sheet of commonly used Docker shell commands. It is meant to serve as a quick reference that you can consult when developing scripts or debugging. It is not a tutorial - if you haven’t used docker before please refer to the official learning materials and documentation.

Docker 101 - Managing a Single Container

Inventory of Containers and Images

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
# Check Docker hub for images with a given name
docker search ubuntu

# Pull a container from Docker hub. To use an image tag - use [image-name]:[tag]
docker pull hello-world
docker pull ubuntu
docker pull ubuntu:12.10

# List all "pulled" images on your local system
docker images

# List all running containers
docker ps

# List all containers (not running as well)
docker ps -a

# List what is running in a container. Id/Name is taken from ps.
docker top 32c5a521c664

Start Containers, Run Commands and Shell (SSH-style)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
# Start a container - pull it from Docker hub if not present. You can name it.
# Standard output/error will be redirected to the current terminal
docker run hello-world
docker run --name=test-container-name hello-world

# Start in detached mode - standard output/error will NOT be redirected to the current terminal
docker run -d hello-world

# Start a container and run a specific command from within
docker run busybox echo "Test\n"
docker run ubuntu /bin/echo hello ubuntu container
run ubuntu /bin/bash -c "ls -l"

# Start a container and run a bash sessions interactively (SSH-style)
docker run -it ubuntu bash
docker run -it ubuntu /bin/bash
docker run -it busybox sh

# Attach a shell into a running container (SSH-style). Id/Name is taken from ps.
sudo docker exec -it b3a04a93f46f bash
sudo docker exec -it b3a04a93f46f sh

# Detach from a container's shell without killing it (keyboard shortcut):
Ctrl + p + q

# Reattach/reconnect to running shell (if doconnected with the above shortcut)
docker attach 32c5a521c664

# Run an arbitrary command within a running container
docker exec b3a04a93f46f /bin/echo "Hello again"

Networking and Persistent Volumes

1
2
3
4
5
6
7
8
9
10
11
# Start a web server in a container; map its port (80) to a localhost port (8080)
docker run -p 8080:80 nginx

# If containers can't access the hosts networking (run on host)
sysctl -w net.ipv4.ip_forward=1

# Force the container to use a specific DNS server
docker run --dns 8.8.8.8 ubuntu

# Mount a host folder '~/test-vol' to a container as '/host-test-vol'
docker run -it -v ~/test-vol:/host-test-vol ubuntu /bin/bash

Restart, Stop, and Delete Containers

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
# Start/restart a stopped/running container
docker start 33712928d6c5
docker restart 33712928d6c5

# Gracefully stop a running container by.
# Sends SIGTERM to the root process.
docker stop b3a04a93f46f

# Forcefully stop a running container (SIGKILL)
docker kill b3a04a93f46f

# Remove a stopped container
docker rm b3a04a93f46f

# Remove a container regardless of its state (i.e. running, stopped)
docker rm -f b3a04a93f46f

Diff a Container and Create an Image

1
2
3
4
5
# Check the changes in a container, since it was started from an image
docker diff 60b4f89dfc7f

# Create an image from a container - it will include all new changes
docker commit 60b4f89dfc7f test-image-name

Dockerfile - Create a New Image

Sample Dockerfile

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
# Define base docker image - will be pulled from the repo if not present
FROM ubuntu:16.04

# Metadata - Let people know who build this
MAINTAINER John Dockerson john.dockerson@dockeremail.com

# Install and set-up the current image - run only when creating the image
RUN apt-get update
RUN apt-get install -y git nginx

# Default working directory of all containers from this image
WORKDIR /var

# Set an env. variable 'APP-VER' for all containers from this image
ENV APP-VER 1.0

# Exposes port 80 - only to other containers! Can't be accessed from localhost.
EXPOSE 80

# Mount a volume from the host - less flexible that '-v' option.
# Can't specify custom mount point.
VOLUME /var/log

# Copy file(s) from the host to the image. If a folder - copies the content!
ADD folder /usr/local/
COPY folder /usr/local/
ADD folder /usr/local/folder
ADD file.txt /usr/local/

# Commands that will run when starting a container - e.g. start web/db server
# If the caller passes a command - this will not run! You can have only 1 CMD command.
CMD service nginx start

# Like CMD, but can't be overridden if the caller passes a command!
ENTRYPOINT service nginx start

Working with Dockerfile

1
2
3
4
5
6
# Build a docker image from Dockerfile in the current folder
docker build .

# Build a docker image from Dockerfile and name it
docker build -t nikolay/testimage .
docker build -t nikolay/testimage:ver1 .

Docker Compose

Example borrowed from the official documentation:

Sample docker-compose.yml File

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
# Use the latest version of docker compose
version: '2'

# Define each container in the services section
services:
# A container from an existing image
  db:
    image: postgres

# A container from a custom image (defined in Dockerfile)
  web:
#   Build the image, map ports, volumes, etc. Specify a command
    build: .
    command: python manage.py runserver 0.0.0.0:8000
    volumes:
      - .:/code
    ports:
      - "8000:8000"
    depends_on:
      - db

Run Docker Compose

1
2
3
4
5
6
7
8
9
# From the same folder - start all containers defined in docker-compose.yml.
# If some of the containers are running - starts only the needed ones
docker-compose up

# Force all containers to be restarted
docker-compose up --force-recreate

# Stop all containers
docker-compose stop