github.com/eikeon/docker@v1.5.0-rc4/docs/sources/userguide/dockerimages.md (about)

     1  page_title: Working with Docker Images
     2  page_description: How to work with Docker images.
     3  page_keywords: documentation, docs, the docker guide, docker guide, docker, docker platform, virtualization framework, docker.io, Docker images, Docker image, image management, Docker repos, Docker repositories, docker, docker tag, docker tags, Docker Hub, collaboration
     4  
     5  # Working with Docker Images
     6  
     7  In the [introduction](/introduction/understanding-docker/) we've discovered that Docker
     8  images are the basis of containers. In the
     9  [previous](/userguide/dockerizing/) [sections](/userguide/usingdocker/)
    10  we've used Docker images that already exist, for example the `ubuntu`
    11  image and the `training/webapp` image.
    12  
    13  We've also discovered that Docker stores downloaded images on the Docker
    14  host. If an image isn't already present on the host then it'll be
    15  downloaded from a registry: by default the
    16  [Docker Hub Registry](https://registry.hub.docker.com).
    17  
    18  In this section we're going to explore Docker images a bit more
    19  including:
    20  
    21  * Managing and working with images locally on your Docker host;
    22  * Creating basic images;
    23  * Uploading images to [Docker Hub Registry](https://registry.hub.docker.com).
    24  
    25  ## Listing images on the host
    26  
    27  Let's start with listing the images we have locally on our host. You can
    28  do this using the `docker images` command like so:
    29  
    30      $ sudo docker images
    31      REPOSITORY       TAG      IMAGE ID      CREATED      VIRTUAL SIZE
    32      training/webapp  latest   fc77f57ad303  3 weeks ago  280.5 MB
    33      ubuntu           13.10    5e019ab7bf6d  4 weeks ago  180 MB
    34      ubuntu           saucy    5e019ab7bf6d  4 weeks ago  180 MB
    35      ubuntu           12.04    74fe38d11401  4 weeks ago  209.6 MB
    36      ubuntu           precise  74fe38d11401  4 weeks ago  209.6 MB
    37      ubuntu           12.10    a7cf8ae4e998  4 weeks ago  171.3 MB
    38      ubuntu           quantal  a7cf8ae4e998  4 weeks ago  171.3 MB
    39      ubuntu           14.04    99ec81b80c55  4 weeks ago  266 MB
    40      ubuntu           latest   99ec81b80c55  4 weeks ago  266 MB
    41      ubuntu           trusty   99ec81b80c55  4 weeks ago  266 MB
    42      ubuntu           13.04    316b678ddf48  4 weeks ago  169.4 MB
    43      ubuntu           raring   316b678ddf48  4 weeks ago  169.4 MB
    44      ubuntu           10.04    3db9c44f4520  4 weeks ago  183 MB
    45      ubuntu           lucid    3db9c44f4520  4 weeks ago  183 MB
    46  
    47  We can see the images we've previously used in our [user guide](/userguide/).
    48  Each has been downloaded from [Docker Hub](https://hub.docker.com) when we
    49  launched a container using that image.
    50  
    51  We can see three crucial pieces of information about our images in the listing.
    52  
    53  * What repository they came from, for example `ubuntu`.
    54  * The tags for each image, for example `14.04`.
    55  * The image ID of each image.
    56  
    57  A repository potentially holds multiple variants of an image. In the case of
    58  our `ubuntu` image we can see multiple variants covering Ubuntu 10.04, 12.04,
    59  12.10, 13.04, 13.10 and 14.04. Each variant is identified by a tag and you can
    60  refer to a tagged image like so:
    61  
    62      ubuntu:14.04
    63  
    64  So when we run a container we refer to a tagged image like so:
    65  
    66      $ sudo docker run -t -i ubuntu:14.04 /bin/bash
    67  
    68  If instead we wanted to run an Ubuntu 12.04 image we'd use:
    69  
    70      $ sudo docker run -t -i ubuntu:12.04 /bin/bash
    71  
    72  If you don't specify a variant, for example you just use `ubuntu`, then Docker
    73  will default to using the `ubuntu:latest` image.
    74  
    75  > **Tip:** 
    76  > We recommend you always use a specific tagged image, for example
    77  > `ubuntu:12.04`. That way you always know exactly what variant of an image is
    78  > being used.
    79  
    80  ## Getting a new image
    81  
    82  So how do we get new images? Well Docker will automatically download any image
    83  we use that isn't already present on the Docker host. But this can potentially
    84  add some time to the launch of a container. If we want to pre-load an image we
    85  can download it using the `docker pull` command. Let's say we'd like to
    86  download the `centos` image.
    87  
    88      $ sudo docker pull centos
    89      Pulling repository centos
    90      b7de3133ff98: Pulling dependent layers
    91      5cc9e91966f7: Pulling fs layer
    92      511136ea3c5a: Download complete
    93      ef52fb1fe610: Download complete
    94      . . .
    95  
    96      Status: Downloaded newer image for centos
    97  
    98  We can see that each layer of the image has been pulled down and now we
    99  can run a container from this image and we won't have to wait to
   100  download the image.
   101  
   102      $ sudo docker run -t -i centos /bin/bash
   103      bash-4.1#
   104  
   105  ## Finding images
   106  
   107  One of the features of Docker is that a lot of people have created Docker
   108  images for a variety of purposes. Many of these have been uploaded to
   109  [Docker Hub](https://hub.docker.com). We can search these images on the
   110  [Docker Hub](https://hub.docker.com) website.
   111  
   112  ![indexsearch](/userguide/search.png)
   113  
   114  We can also search for images on the command line using the `docker search`
   115  command. Let's say our team wants an image with Ruby and Sinatra installed on
   116  which to do our web application development. We can search for a suitable image
   117  by using the `docker search` command to find all the images that contain the
   118  term `sinatra`.
   119  
   120      $ sudo docker search sinatra
   121      NAME                                   DESCRIPTION                                     STARS     OFFICIAL   AUTOMATED
   122      training/sinatra                       Sinatra training image                          0                    [OK]
   123      marceldegraaf/sinatra                  Sinatra test app                                0
   124      mattwarren/docker-sinatra-demo                                                         0                    [OK]
   125      luisbebop/docker-sinatra-hello-world                                                   0                    [OK]
   126      bmorearty/handson-sinatra              handson-ruby + Sinatra for Hands on with D...   0
   127      subwiz/sinatra                                                                         0
   128      bmorearty/sinatra                                                                      0
   129      . . .
   130  
   131  We can see we've returned a lot of images that use the term `sinatra`. We've
   132  returned a list of image names, descriptions, Stars (which measure the social
   133  popularity of images - if a user likes an image then they can "star" it), and
   134  the Official and Automated build statuses. Official repositories are built and
   135  maintained by the [Stackbrew](https://github.com/docker/stackbrew) project,
   136  and Automated repositories are [Automated Builds](
   137  /userguide/dockerrepos/#automated-builds) that allow you to validate the source
   138  and content of an image.
   139  
   140  We've reviewed the images available to use and we decided to use the
   141  `training/sinatra` image. So far we've seen two types of images repositories,
   142  images like `ubuntu`, which are called base or root images. These base images
   143  are provided by Docker Inc and are built, validated and supported. These can be
   144  identified by their single word names.
   145  
   146  We've also seen user images, for example the `training/sinatra` image we've
   147  chosen. A user image belongs to a member of the Docker community and is built
   148  and maintained by them.  You can identify user images as they are always
   149  prefixed with the user name, here `training`, of the user that created them.
   150  
   151  ## Pulling our image
   152  
   153  We've identified a suitable image, `training/sinatra`, and now we can download it using the `docker pull` command.
   154  
   155      $ sudo docker pull training/sinatra
   156  
   157  The team can now use this image by running their own containers.
   158  
   159      $ sudo docker run -t -i training/sinatra /bin/bash
   160      root@a8cb6ce02d85:/#
   161  
   162  ## Creating our own images
   163  
   164  The team has found the `training/sinatra` image pretty useful but it's not quite what
   165  they need and we need to make some changes to it. There are two ways we can
   166  update and create images.
   167  
   168  1. We can update a container created from an image and commit the results to an image.
   169  2. We can use a `Dockerfile` to specify instructions to create an image.
   170  
   171  
   172  ### Updating and committing an image
   173  
   174  To update an image we first need to create a container from the image
   175  we'd like to update.
   176  
   177      $ sudo docker run -t -i training/sinatra /bin/bash
   178      root@0b2616b0e5a8:/#
   179  
   180  > **Note:** 
   181  > Take note of the container ID that has been created, `0b2616b0e5a8`, as we'll
   182  > need it in a moment.
   183  
   184  Inside our running container let's add the `json` gem.
   185  
   186      root@0b2616b0e5a8:/# gem install json
   187  
   188  Once this has completed let's exit our container using the `exit`
   189  command.
   190  
   191  Now we have a container with the change we want to make. We can then
   192  commit a copy of this container to an image using the `docker commit`
   193  command.
   194  
   195      $ sudo docker commit -m "Added json gem" -a "Kate Smith" \
   196      0b2616b0e5a8 ouruser/sinatra:v2
   197      4f177bd27a9ff0f6dc2a830403925b5360bfe0b93d476f7fc3231110e7f71b1c
   198  
   199  Here we've used the `docker commit` command. We've specified two flags: `-m`
   200  and `-a`. The `-m` flag allows us to specify a commit message, much like you
   201  would with a commit on a version control system. The `-a` flag allows us to
   202  specify an author for our update.
   203  
   204  We've also specified the container we want to create this new image from,
   205  `0b2616b0e5a8` (the ID we recorded earlier) and we've specified a target for
   206  the image:
   207  
   208      ouruser/sinatra:v2
   209  
   210  Let's break this target down. It consists of a new user, `ouruser`, that we're
   211  writing this image to. We've also specified the name of the image, here we're
   212  keeping the original image name `sinatra`. Finally we're specifying a tag for
   213  the image: `v2`.
   214  
   215  We can then look at our new `ouruser/sinatra` image using the `docker images`
   216  command.
   217  
   218      $ sudo docker images
   219      REPOSITORY          TAG     IMAGE ID       CREATED       VIRTUAL SIZE
   220      training/sinatra    latest  5bc342fa0b91   10 hours ago  446.7 MB
   221      ouruser/sinatra     v2      3c59e02ddd1a   10 hours ago  446.7 MB
   222      ouruser/sinatra     latest  5db5f8471261   10 hours ago  446.7 MB
   223  
   224  To use our new image to create a container we can then:
   225  
   226      $ sudo docker run -t -i ouruser/sinatra:v2 /bin/bash
   227      root@78e82f680994:/#
   228  
   229  ### Building an image from a `Dockerfile`
   230  
   231  Using the `docker commit` command is a pretty simple way of extending an image
   232  but it's a bit cumbersome and it's not easy to share a development process for
   233  images amongst a team. Instead we can use a new command, `docker build`, to
   234  build new images from scratch.
   235  
   236  To do this we create a `Dockerfile` that contains a set of instructions that
   237  tell Docker how to build our image.
   238  
   239  Let's create a directory and a `Dockerfile` first.
   240  
   241      $ mkdir sinatra
   242      $ cd sinatra
   243      $ touch Dockerfile
   244  
   245  Each instruction creates a new layer of the image. Let's look at a simple
   246  example now for building our own Sinatra image for our development team.
   247  
   248      # This is a comment
   249      FROM ubuntu:14.04
   250      MAINTAINER Kate Smith <ksmith@example.com>
   251      RUN apt-get update && apt-get install -y ruby ruby-dev
   252      RUN gem install sinatra
   253  
   254  Let's look at what our `Dockerfile` does. Each instruction prefixes a statement and is capitalized.
   255  
   256      INSTRUCTION statement
   257  
   258  > **Note:**
   259  > We use `#` to indicate a comment
   260  
   261  The first instruction `FROM` tells Docker what the source of our image is, in
   262  this case we're basing our new image on an Ubuntu 14.04 image.
   263  
   264  Next we use the `MAINTAINER` instruction to specify who maintains our new image.
   265  
   266  Lastly, we've specified three `RUN` instructions. A `RUN` instruction executes
   267  a command inside the image, for example installing a package. Here we're
   268  updating our APT cache, installing Ruby and RubyGems and then installing the
   269  Sinatra gem.
   270  
   271  > **Note:** 
   272  > There are [a lot more instructions available to us in a Dockerfile](/reference/builder).
   273  
   274  Now let's take our `Dockerfile` and use the `docker build` command to build an image.
   275  
   276      $ sudo docker build -t ouruser/sinatra:v2 .
   277      Sending build context to Docker daemon 2.048 kB
   278      Sending build context to Docker daemon 
   279      Step 0 : FROM ubuntu:14.04
   280       ---> e54ca5efa2e9
   281      Step 1 : MAINTAINER Kate Smith <ksmith@example.com>
   282       ---> Using cache
   283       ---> 851baf55332b
   284      Step 2 : RUN apt-get update && apt-get install -y ruby ruby-dev
   285       ---> Running in 3a2558904e9b
   286      Selecting previously unselected package libasan0:amd64.
   287      (Reading database ... 11518 files and directories currently installed.)
   288      Preparing to unpack .../libasan0_4.8.2-19ubuntu1_amd64.deb ...
   289      Unpacking libasan0:amd64 (4.8.2-19ubuntu1) ...
   290      Selecting previously unselected package libatomic1:amd64.
   291      Preparing to unpack .../libatomic1_4.8.2-19ubuntu1_amd64.deb ...
   292      Unpacking libatomic1:amd64 (4.8.2-19ubuntu1) ...
   293      Selecting previously unselected package libgmp10:amd64.
   294      Preparing to unpack .../libgmp10_2%3a5.1.3+dfsg-1ubuntu1_amd64.deb ...
   295      Unpacking libgmp10:amd64 (2:5.1.3+dfsg-1ubuntu1) ...
   296      Selecting previously unselected package libisl10:amd64.
   297      Preparing to unpack .../libisl10_0.12.2-1_amd64.deb ...
   298      Unpacking libisl10:amd64 (0.12.2-1) ...
   299      Selecting previously unselected package libcloog-isl4:amd64.
   300      Preparing to unpack .../libcloog-isl4_0.18.2-1_amd64.deb ...
   301      Unpacking libcloog-isl4:amd64 (0.18.2-1) ...
   302      Selecting previously unselected package libgomp1:amd64.
   303      Preparing to unpack .../libgomp1_4.8.2-19ubuntu1_amd64.deb ...
   304      Unpacking libgomp1:amd64 (4.8.2-19ubuntu1) ...
   305      Selecting previously unselected package libitm1:amd64.
   306      Preparing to unpack .../libitm1_4.8.2-19ubuntu1_amd64.deb ...
   307      Unpacking libitm1:amd64 (4.8.2-19ubuntu1) ...
   308      Selecting previously unselected package libmpfr4:amd64.
   309      Preparing to unpack .../libmpfr4_3.1.2-1_amd64.deb ...
   310      Unpacking libmpfr4:amd64 (3.1.2-1) ...
   311      Selecting previously unselected package libquadmath0:amd64.
   312      Preparing to unpack .../libquadmath0_4.8.2-19ubuntu1_amd64.deb ...
   313      Unpacking libquadmath0:amd64 (4.8.2-19ubuntu1) ...
   314      Selecting previously unselected package libtsan0:amd64.
   315      Preparing to unpack .../libtsan0_4.8.2-19ubuntu1_amd64.deb ...
   316      Unpacking libtsan0:amd64 (4.8.2-19ubuntu1) ...
   317      Selecting previously unselected package libyaml-0-2:amd64.
   318      Preparing to unpack .../libyaml-0-2_0.1.4-3ubuntu3_amd64.deb ...
   319      Unpacking libyaml-0-2:amd64 (0.1.4-3ubuntu3) ...
   320      Selecting previously unselected package libmpc3:amd64.
   321      Preparing to unpack .../libmpc3_1.0.1-1ubuntu1_amd64.deb ...
   322      Unpacking libmpc3:amd64 (1.0.1-1ubuntu1) ...
   323      Selecting previously unselected package openssl.
   324      Preparing to unpack .../openssl_1.0.1f-1ubuntu2.4_amd64.deb ...
   325      Unpacking openssl (1.0.1f-1ubuntu2.4) ...
   326      Selecting previously unselected package ca-certificates.
   327      Preparing to unpack .../ca-certificates_20130906ubuntu2_all.deb ...
   328      Unpacking ca-certificates (20130906ubuntu2) ...
   329      Selecting previously unselected package manpages.
   330      Preparing to unpack .../manpages_3.54-1ubuntu1_all.deb ...
   331      Unpacking manpages (3.54-1ubuntu1) ...
   332      Selecting previously unselected package binutils.
   333      Preparing to unpack .../binutils_2.24-5ubuntu3_amd64.deb ...
   334      Unpacking binutils (2.24-5ubuntu3) ...
   335      Selecting previously unselected package cpp-4.8.
   336      Preparing to unpack .../cpp-4.8_4.8.2-19ubuntu1_amd64.deb ...
   337      Unpacking cpp-4.8 (4.8.2-19ubuntu1) ...
   338      Selecting previously unselected package cpp.
   339      Preparing to unpack .../cpp_4%3a4.8.2-1ubuntu6_amd64.deb ...
   340      Unpacking cpp (4:4.8.2-1ubuntu6) ...
   341      Selecting previously unselected package libgcc-4.8-dev:amd64.
   342      Preparing to unpack .../libgcc-4.8-dev_4.8.2-19ubuntu1_amd64.deb ...
   343      Unpacking libgcc-4.8-dev:amd64 (4.8.2-19ubuntu1) ...
   344      Selecting previously unselected package gcc-4.8.
   345      Preparing to unpack .../gcc-4.8_4.8.2-19ubuntu1_amd64.deb ...
   346      Unpacking gcc-4.8 (4.8.2-19ubuntu1) ...
   347      Selecting previously unselected package gcc.
   348      Preparing to unpack .../gcc_4%3a4.8.2-1ubuntu6_amd64.deb ...
   349      Unpacking gcc (4:4.8.2-1ubuntu6) ...
   350      Selecting previously unselected package libc-dev-bin.
   351      Preparing to unpack .../libc-dev-bin_2.19-0ubuntu6_amd64.deb ...
   352      Unpacking libc-dev-bin (2.19-0ubuntu6) ...
   353      Selecting previously unselected package linux-libc-dev:amd64.
   354      Preparing to unpack .../linux-libc-dev_3.13.0-30.55_amd64.deb ...
   355      Unpacking linux-libc-dev:amd64 (3.13.0-30.55) ...
   356      Selecting previously unselected package libc6-dev:amd64.
   357      Preparing to unpack .../libc6-dev_2.19-0ubuntu6_amd64.deb ...
   358      Unpacking libc6-dev:amd64 (2.19-0ubuntu6) ...
   359      Selecting previously unselected package ruby.
   360      Preparing to unpack .../ruby_1%3a1.9.3.4_all.deb ...
   361      Unpacking ruby (1:1.9.3.4) ...
   362      Selecting previously unselected package ruby1.9.1.
   363      Preparing to unpack .../ruby1.9.1_1.9.3.484-2ubuntu1_amd64.deb ...
   364      Unpacking ruby1.9.1 (1.9.3.484-2ubuntu1) ...
   365      Selecting previously unselected package libruby1.9.1.
   366      Preparing to unpack .../libruby1.9.1_1.9.3.484-2ubuntu1_amd64.deb ...
   367      Unpacking libruby1.9.1 (1.9.3.484-2ubuntu1) ...
   368      Selecting previously unselected package manpages-dev.
   369      Preparing to unpack .../manpages-dev_3.54-1ubuntu1_all.deb ...
   370      Unpacking manpages-dev (3.54-1ubuntu1) ...
   371      Selecting previously unselected package ruby1.9.1-dev.
   372      Preparing to unpack .../ruby1.9.1-dev_1.9.3.484-2ubuntu1_amd64.deb ...
   373      Unpacking ruby1.9.1-dev (1.9.3.484-2ubuntu1) ...
   374      Selecting previously unselected package ruby-dev.
   375      Preparing to unpack .../ruby-dev_1%3a1.9.3.4_all.deb ...
   376      Unpacking ruby-dev (1:1.9.3.4) ...
   377      Setting up libasan0:amd64 (4.8.2-19ubuntu1) ...
   378      Setting up libatomic1:amd64 (4.8.2-19ubuntu1) ...
   379      Setting up libgmp10:amd64 (2:5.1.3+dfsg-1ubuntu1) ...
   380      Setting up libisl10:amd64 (0.12.2-1) ...
   381      Setting up libcloog-isl4:amd64 (0.18.2-1) ...
   382      Setting up libgomp1:amd64 (4.8.2-19ubuntu1) ...
   383      Setting up libitm1:amd64 (4.8.2-19ubuntu1) ...
   384      Setting up libmpfr4:amd64 (3.1.2-1) ...
   385      Setting up libquadmath0:amd64 (4.8.2-19ubuntu1) ...
   386      Setting up libtsan0:amd64 (4.8.2-19ubuntu1) ...
   387      Setting up libyaml-0-2:amd64 (0.1.4-3ubuntu3) ...
   388      Setting up libmpc3:amd64 (1.0.1-1ubuntu1) ...
   389      Setting up openssl (1.0.1f-1ubuntu2.4) ...
   390      Setting up ca-certificates (20130906ubuntu2) ...
   391      debconf: unable to initialize frontend: Dialog
   392      debconf: (TERM is not set, so the dialog frontend is not usable.)
   393      debconf: falling back to frontend: Readline
   394      debconf: unable to initialize frontend: Readline
   395      debconf: (This frontend requires a controlling tty.)
   396      debconf: falling back to frontend: Teletype
   397      Setting up manpages (3.54-1ubuntu1) ...
   398      Setting up binutils (2.24-5ubuntu3) ...
   399      Setting up cpp-4.8 (4.8.2-19ubuntu1) ...
   400      Setting up cpp (4:4.8.2-1ubuntu6) ...
   401      Setting up libgcc-4.8-dev:amd64 (4.8.2-19ubuntu1) ...
   402      Setting up gcc-4.8 (4.8.2-19ubuntu1) ...
   403      Setting up gcc (4:4.8.2-1ubuntu6) ...
   404      Setting up libc-dev-bin (2.19-0ubuntu6) ...
   405      Setting up linux-libc-dev:amd64 (3.13.0-30.55) ...
   406      Setting up libc6-dev:amd64 (2.19-0ubuntu6) ...
   407      Setting up manpages-dev (3.54-1ubuntu1) ...
   408      Setting up libruby1.9.1 (1.9.3.484-2ubuntu1) ...
   409      Setting up ruby1.9.1-dev (1.9.3.484-2ubuntu1) ...
   410      Setting up ruby-dev (1:1.9.3.4) ...
   411      Setting up ruby (1:1.9.3.4) ...
   412      Setting up ruby1.9.1 (1.9.3.484-2ubuntu1) ...
   413      Processing triggers for libc-bin (2.19-0ubuntu6) ...
   414      Processing triggers for ca-certificates (20130906ubuntu2) ...
   415      Updating certificates in /etc/ssl/certs... 164 added, 0 removed; done.
   416      Running hooks in /etc/ca-certificates/update.d....done.
   417       ---> c55c31703134
   418      Removing intermediate container 3a2558904e9b
   419      Step 3 : RUN gem install sinatra
   420       ---> Running in 6b81cb6313e5
   421      unable to convert "\xC3" to UTF-8 in conversion from ASCII-8BIT to UTF-8 to US-ASCII for README.rdoc, skipping
   422      unable to convert "\xC3" to UTF-8 in conversion from ASCII-8BIT to UTF-8 to US-ASCII for README.rdoc, skipping
   423      Successfully installed rack-1.5.2
   424      Successfully installed tilt-1.4.1
   425      Successfully installed rack-protection-1.5.3
   426      Successfully installed sinatra-1.4.5
   427      4 gems installed
   428      Installing ri documentation for rack-1.5.2...
   429      Installing ri documentation for tilt-1.4.1...
   430      Installing ri documentation for rack-protection-1.5.3...
   431      Installing ri documentation for sinatra-1.4.5...
   432      Installing RDoc documentation for rack-1.5.2...
   433      Installing RDoc documentation for tilt-1.4.1...
   434      Installing RDoc documentation for rack-protection-1.5.3...
   435      Installing RDoc documentation for sinatra-1.4.5...
   436       ---> 97feabe5d2ed
   437      Removing intermediate container 6b81cb6313e5
   438      Successfully built 97feabe5d2ed
   439  
   440  We've specified our `docker build` command and used the `-t` flag to identify
   441  our new image as belonging to the user `ouruser`, the repository name `sinatra`
   442  and given it the tag `v2`.
   443  
   444  We've also specified the location of our `Dockerfile` using the `.` to
   445  indicate a `Dockerfile` in the current directory.
   446  
   447  > **Note:**
   448  > You can also specify a path to a `Dockerfile`.
   449  
   450  Now we can see the build process at work. The first thing Docker does is
   451  upload the build context: basically the contents of the directory you're
   452  building in. This is done because the Docker daemon does the actual
   453  build of the image and it needs the local context to do it.
   454  
   455  Next we can see each instruction in the `Dockerfile` being executed
   456  step-by-step. We can see that each step creates a new container, runs
   457  the instruction inside that container and then commits that change -
   458  just like the `docker commit` work flow we saw earlier. When all the
   459  instructions have executed we're left with the `97feabe5d2ed` image
   460  (also helpfully tagged as `ouruser/sinatra:v2`) and all intermediate
   461  containers will get removed to clean things up.
   462  
   463  > **Note:** 
   464  > An image can't have more than 127 layers regardless of the storage driver.
   465  > This limitation is set globally to encourage optimization of the overall 
   466  > size of images.
   467  
   468  We can then create a container from our new image.
   469  
   470      $ sudo docker run -t -i ouruser/sinatra:v2 /bin/bash
   471      root@8196968dac35:/#
   472  
   473  > **Note:** 
   474  > This is just a brief introduction to creating images. We've
   475  > skipped a whole bunch of other instructions that you can use. We'll see more of
   476  > those instructions in later sections of the Guide or you can refer to the
   477  > [`Dockerfile`](/reference/builder/) reference for a
   478  > detailed description and examples of every instruction.
   479  > To help you write a clear, readable, maintainable `Dockerfile`, we've also
   480  > written a [`Dockerfile` Best Practices guide](/articles/dockerfile_best-practices).
   481  
   482  ### More
   483  
   484  To learn more, check out the [Dockerfile tutorial](/userguide/level1).
   485  
   486  ## Setting tags on an image
   487  
   488  You can also add a tag to an existing image after you commit or build it. We
   489  can do this using the `docker tag` command. Let's add a new tag to our
   490  `ouruser/sinatra` image.
   491  
   492      $ sudo docker tag 5db5f8471261 ouruser/sinatra:devel
   493  
   494  The `docker tag` command takes the ID of the image, here `5db5f8471261`, and our
   495  user name, the repository name and the new tag.
   496  
   497  Let's see our new tag using the `docker images` command.
   498  
   499      $ sudo docker images ouruser/sinatra
   500      REPOSITORY          TAG     IMAGE ID      CREATED        VIRTUAL SIZE
   501      ouruser/sinatra     latest  5db5f8471261  11 hours ago   446.7 MB
   502      ouruser/sinatra     devel   5db5f8471261  11 hours ago   446.7 MB
   503      ouruser/sinatra     v2      5db5f8471261  11 hours ago   446.7 MB
   504  
   505  ## Push an image to Docker Hub
   506  
   507  Once you've built or created a new image you can push it to [Docker
   508  Hub](https://hub.docker.com) using the `docker push` command. This
   509  allows you to share it with others, either publicly, or push it into [a
   510  private repository](https://registry.hub.docker.com/plans/).
   511  
   512      $ sudo docker push ouruser/sinatra
   513      The push refers to a repository [ouruser/sinatra] (len: 1)
   514      Sending image list
   515      Pushing repository ouruser/sinatra (3 tags)
   516      . . .
   517  
   518  ## Remove an image from the host
   519  
   520  You can also remove images on your Docker host in a way [similar to
   521  containers](
   522  /userguide/usingdocker) using the `docker rmi` command.
   523  
   524  Let's delete the `training/sinatra` image as we don't need it anymore.
   525  
   526      $ sudo docker rmi training/sinatra
   527      Untagged: training/sinatra:latest
   528      Deleted: 5bc342fa0b91cabf65246837015197eecfa24b2213ed6a51a8974ae250fedd8d
   529      Deleted: ed0fffdcdae5eb2c3a55549857a8be7fc8bc4241fb19ad714364cbfd7a56b22f
   530      Deleted: 5c58979d73ae448df5af1d8142436d81116187a7633082650549c52c3a2418f0
   531  
   532  > **Note:** In order to remove an image from the host, please make sure
   533  > that there are no containers actively based on it.
   534  
   535  # Next steps
   536  
   537  Until now we've seen how to build individual applications inside Docker
   538  containers. Now learn how to build whole application stacks with Docker
   539  by linking together multiple Docker containers.
   540  
   541  Test your Dockerfile knowledge with the
   542  [Dockerfile tutorial](/userguide/level1).
   543  
   544  Go to [Linking Containers Together](/userguide/dockerlinks).
   545  
   546