PURPOSE: This chapter explains how to create a Docker image.
As explained in [Docker_Basics], Docker image is the build component of Docker and a read-only template of application operating system.
Docker build images by reading instructions from a Dockerfile. A Dockerfile is a text document that contains all the commands a user could call on the command line to assemble an image. docker build
command uses this file and executes all the commands in succession to create an image.
build
command is also passed a context that is used during image creation. This context can be a path on your local filesystem or a URL to a Git repository.
Dockerfile is usually called Dockerfile. The complete list of commands that can be specified in this file are explained at https://docs.docker.com/reference/builder/. The common commands are listed below:
Command | Purpose | Example |
---|---|---|
FROM |
First non-comment instruction in Dockerfile |
|
COPY |
Copies mulitple source files from the context to the file system of the container at the specified path |
|
ENV |
Sets the environment variable |
|
RUN |
Executes a command |
|
CMD |
Defaults for an executing container |
|
EXPOSE |
Informs the network ports that the container will listen on |
|
Hello World Dockerfile is shown:
FROM ubuntu
CMD ["/bin/echo", "hello world"]
This image uses ubuntu
as the base image. CMD
command defines the command that needs to run. It provides a different entry point of /bin/echo
and gives the argument “hello world”.
Build this image as:
> docker build -t helloworld .
Sending build context to Docker daemon 2.048 kB
Step 0 : FROM ubuntu
Pulling repository docker.io/library/ubuntu
a5a467fddcb8: Download complete
3fd0c2ae8ed2: Download complete
9e19ac89d27c: Download complete
ac65c371c3a5: Download complete
Status: Downloaded newer image for ubuntu:latest
---> a5a467fddcb8
Step 1 : CMD /bin/echo hello world
---> Running in 132bb0bf823f
---> e81a394f71e3
Removing intermediate container 132bb0bf823f
Successfully built e81a394f71e3
List the images available:
> docker images
REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
helloworld latest 9c0e7b56cbee 13 minutes ago 187.9 MB
Run the container:
docker run -it helloworld
to see the output:
hello world
Change the base image from ubuntu
to busybox
, build the image again:
docker build -t helloworld2 .
> docker images
REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
helloworld latest e81a394f71e3 26 minutes ago 187.9 MB
helloworld2 latest c458787fadcf 3 seconds ago 1.113 MB
ubuntu latest a5a467fddcb8 2 days ago 187.9 MB
busybox latest 3d5bcd78e074 4 days ago 1.113 MB
Create a new text file Dockerfile in an empty directory:
FROM jboss/wildfly
Build the image:
docker build -t mywildfly .
Run the container:
docker run -it mywildfly
Create a new text file Dockerfile in an empty directory:
FROM jboss/wildfly
CMD ["/opt/jboss/wildfly/bin/standalone.sh", "-c", "standalone-full.xml", "-b", "0.0.0.0"]
RUN curl -L https://github.com/javaee-samples/javaee7-hol/raw/master/solution/movieplex7-1.0-SNAPSHOT.war -o /opt/jboss/wildfly/standalone/deployments/movieplex7-1.0-SNAPSHOT.war
Three things happen in this image: . Uses “jboss/wildfly” as the base image . Starts WildFly application server in Full Platform mode . Copies the WAR file from from a URL to the deployment directory of WildFly
Build the image:
docker build -t movieplex .
TL;DR CMD
will work for most of the cases.
Default entry point for a container is /bin/sh
, the default shell.
Running a container as docker run -it ubuntu
uses that command and starts the default shell. The output is shown as:
> docker run -it ubuntu
root@88976ddee107:/#
ENTRYPOINT
allows to override the entry point to some other command, and even customize it. For example, a container can be started as:
> docker run -it --entrypoint=/bin/cat ubuntu /etc/passwd
root:x:0:0:root:/root:/bin/bash
daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin
bin:x:2:2:bin:/bin:/usr/sbin/nologin
sys:x:3:3:sys:/dev:/usr/sbin/nologin
. . .
This command overrides the entry point to the container to /bin/cat
. The argument(s) passed to the CLI are used by the entry point.
TL;DR COPY
will work for most of the cases.
ADD
has all capabilities of COPY
and has the following additional features:
-
Allows tar file auto-extraction in the image, for example,
ADD app.tar.gz /opt/var/myapp
. -
Allows files to be downloaded from a remote URL. However, the downloaded files will become part of the image. This causes the image size to bloat. So its recommended to use
curl
orwget
to download the archive explicitly, extract, and remove the archive.