Docker containers
Launch a container
We launch a container by running, e.g
docker run hello-world
Docker looks for the hello-world
image in order to start the container. If it cannot find it, it will fetch the image from DockerHub.
(docker run
assumes you are saying “run image in container” but you can specify other Docker objects such as networks.)
The docker run
command is actually a composite of the following two commands:
docker create --name [my_container_name] hello-world
docker start [my_container]
Here is an applied example:
docker run --name my-container debian /bin/echo "Hello, world"
This creates and runs a container from the Debian image and executes /bin/echo
inside of it. Once you have run the above line, if the process is successful it will exit. The container will stop running but it will remain in memory. Nothing will be output (no “Hello, world”), because when you run it, you are outside of the container.
Launch a container as a daemon
You can also run a container as a daemon. In this mode, the container will run in the background and detach from the console. For example:
docker run -d debian /bin/sh -c /bin/sh -c "while true; do echo 'Hello!'; sleep 1; done"
Inside the container, this will echo “Hello!” every second in an infinite loop whilst the daemon is active.
The above command will not actually output anything. Instead it wil ouput the container ID, e.g:
2749d796cbd64e9cf57307329e792587c39d8244f2377e62d78f3f3f77eecdb4
You can use this to access the log for the container. When you do so, you will then see the output:
docker log 2749
hello
hello
hello
...
(We could also use the container name to reference the container, if we launched it with the --name
param.)
Stopping a container
docker stop 2749
There will be a delay because it shuts down gracefully. It sends a SIGINT to the process in the container with PID 1 (i.e the root or parent process for the container).
stop
will keep the container in memory. This means you can still refer bak to the logs and that it can be restarted.
Instead of stop
, if you were to use:
docker rm 2749
The container will be stopped and deleted. The logs are deleted and the container cannot be recovered.
We can also tell Docker to immediately remove a container after it exits:
docker run --rm [image]
Interacting with containers
In the examples so far the container is a closed box. You don’t have a terminal through which you can interact with the container as you would with an OS. You can only start the container and view its activities by accessing the logs.
For images that have an OS we can use -i -t
to launch a terminal in interactive mode.
docker run -i -t debian /bin/bash
root@0022da12f2f2:/# ls
bin boot dev etc home lib media mnt opt proc root run sbin srv sys tmp usr var
root@0022da12f2f2:/# whoami
root
root@0022da12f2f2:/# ls usr/
bin games include lib libexec local sbin share src
Note that it defaults to the root user.
Containers are lightweight and should only contain the minium environment needed to run an application. For this reason OSs that are included in an image are often very stripped-back and many programs and processes will not be there by default. (Although you could install a package manager and install the commands you need.)
The previous command launches the container and enters into it with a terminal. If a container is already running, you can enter into it in terminal mode with exec
:
docker exec -i -t my_container bash
If a container is running in detached mode we can attach to the main process with docker attach
docker attach my_container
Container lifecycle
All containers have a lifecycle represented by five distinct states. Each state has an associated command:
- created
docker create
,docker run
- running
- paused
docker pause
,docker unpause
- stopped
docker stop
,docker kill
- removed
docker rm
Main container commands
docker create # create container from image
docker run # create and start container from image
docker run --name # add custom name for container
docker ps # list currently active containers
docker ps -a # list all containers (inactive and active)
docker logs # display a container log
docker stop # stop a running container
docker start # starts a stopped (exited) container
docker rm # remove a stopped (exited) container
Container troubleshooting
Lots of diagnostic output:
docker inspect container_name
List processes (from outside):
docker top container_name
View logs
docker logs container_name