README.md
10005433
 Docker: the container engine [![Release](https://img.shields.io/github/release/docker/docker.svg)](https://github.com/docker/docker/releases/latest)
faf9e340
 ============================
0db56e6c
 
70ab25a5
 Docker is an open source project to pack, ship and run any application
f9d323d7
 as a lightweight container.
63ce0810
 
046e6604
 Docker containers are both *hardware-agnostic* and *platform-agnostic*.
99a5da5a
 This means they can run anywhere, from your laptop to the largest
faf9e340
 cloud compute instance and everything in between - and they don't require
99a5da5a
 you to use a particular language, framework or packaging system. That
046e6604
 makes them great building blocks for deploying and scaling web apps,
99a5da5a
 databases, and backend services without depending on a particular stack
046e6604
 or provider.
0db56e6c
 
99a5da5a
 Docker began as an open-source implementation of the deployment engine which
4ca0aad8
 powers [dotCloud](https://www.dotcloud.com), a popular Platform-as-a-Service.
046e6604
 It benefits directly from the experience accumulated over several years
 of large-scale operation and support of hundreds of thousands of
 applications and databases.
0db56e6c
 
38a58a4a
 ![](docs/static_files/docker-logo-compressed.png "Docker")
2ac7298e
 
9e2cc4fc
 ## Security Disclosure
 
99a5da5a
 Security is very important to us. If you have any issue regarding security, 
d9d08c5e
 please disclose the information responsibly by sending an email to 
 security@docker.com and not by creating a github issue.
9e2cc4fc
 
15612322
 ## Better than VMs
0db56e6c
 
33ee7800
 A common method for distributing applications and sandboxing their
78c02d03
 execution is to use virtual machines, or VMs. Typical VM formats are
9030f531
 VMware's vmdk, Oracle VirtualBox's vdi, and Amazon EC2's ami. In theory
046e6604
 these formats should allow every developer to automatically package
 their application into a "machine" for easy distribution and deployment.
 In practice, that almost never happens, for a few reasons:
78c02d03
 
   * *Size*: VMs are very large which makes them impractical to store
      and transfer.
   * *Performance*: running VMs consumes significant CPU and memory,
     which makes them impractical in many scenarios, for example local
     development of multi-tier applications, and large-scale deployment
     of cpu and memory-intensive applications on large numbers of
     machines.
   * *Portability*: competing VM environments don't play well with each
      other. Although conversion tools do exist, they are limited and
      add even more overhead.
   * *Hardware-centric*: VMs were designed with machine operators in
     mind, not software developers. As a result, they offer very
     limited tooling for what developers need most: building, testing
     and running their software. For example, VMs offer no facilities
     for application versioning, monitoring, configuration, logging or
     service discovery.
 
 By contrast, Docker relies on a different sandboxing method known as
046e6604
 *containerization*. Unlike traditional virtualization, containerization
 takes place at the kernel level. Most modern operating system kernels
 now support the primitives necessary for containerization, including
787d774a
 Linux with [openvz](https://openvz.org),
78c02d03
 [vserver](http://linux-vserver.org) and more recently
2b69b326
 [lxc](https://linuxcontainers.org/), Solaris with
787d774a
 [zones](https://docs.oracle.com/cd/E26502_01/html/E29024/preface-1.html#scrolltoc),
78c02d03
 and FreeBSD with
787d774a
 [Jails](https://www.freebsd.org/doc/handbook/jails.html).
78c02d03
 
046e6604
 Docker builds on top of these low-level primitives to offer developers a
99a5da5a
 portable format and runtime environment that solves all four problems.
046e6604
 Docker containers are small (and their transfer can be optimized with
 layers), they have basically zero memory and cpu overhead, they are
99a5da5a
 completely portable, and are designed from the ground up with an
046e6604
 application-centric design.
78c02d03
 
99a5da5a
 Perhaps best of all, because Docker operates at the OS level, it can still be
046e6604
 run inside a VM!
5e2cec7b
 
15612322
 ## Plays well with others
5e2cec7b
 
99a5da5a
 Docker does not require you to buy into a particular programming
 language, framework, packaging system, or configuration language.
5e2cec7b
 
046e6604
 Is your application a Unix process? Does it use files, tcp connections,
 environment variables, standard Unix streams and command-line arguments
 as inputs and outputs? Then Docker can run it.
5e2cec7b
 
78c02d03
 Can your application's build be expressed as a sequence of such
046e6604
 commands? Then Docker can build it.
5e2cec7b
 
15612322
 ## Escape dependency hell
 
78c02d03
 A common problem for developers is the difficulty of managing all
 their application's dependencies in a simple and automated way.
15612322
 
 This is usually difficult for several reasons:
 
78c02d03
   * *Cross-platform dependencies*. Modern applications often depend on
     a combination of system libraries and binaries, language-specific
     packages, framework-specific modules, internal components
     developed for another project, etc. These dependencies live in
     different "worlds" and require different tools - these tools
     typically don't work well with each other, requiring awkward
     custom integrations.
 
21fcca7f
   * *Conflicting dependencies*. Different applications may depend on
78c02d03
     different versions of the same dependency. Packaging tools handle
     these situations with various degrees of ease - but they all
     handle them in different and incompatible ways, which again forces
     the developer to do extra work.
f9d323d7
 
21fcca7f
   * *Custom dependencies*. A developer may need to prepare a custom
78c02d03
     version of their application's dependency. Some packaging systems
     can handle custom versions of a dependency, others can't - and all
     of them handle it differently.
15612322
 
 
99a5da5a
 Docker solves the problem of dependency hell by giving the developer a simple
 way to express *all* their application's dependencies in one place, while
 streamlining the process of assembling them. If this makes you think of
787d774a
 [XKCD 927](https://xkcd.com/927/), don't worry. Docker doesn't
78c02d03
 *replace* your favorite packaging systems. It simply orchestrates
 their use in a simple and repeatable way. How does it do that? With
 layers.
15612322
 
78c02d03
 Docker defines a build as running a sequence of Unix commands, one
 after the other, in the same container. Build commands modify the
 contents of the container (usually by installing new files on the
 filesystem), the next command modifies it some more, etc. Since each
 build command inherits the result of the previous commands, the
 *order* in which the commands are executed expresses *dependencies*.
15612322
 
78c02d03
 Here's a typical Docker build process:
15612322
 
 ```bash
046e6604
 FROM ubuntu:12.04
fc637b52
 RUN apt-get update && apt-get install -y python python-pip curl
9f61e233
 RUN curl -sSL https://github.com/shykes/helloflask/archive/master.tar.gz | tar -xzv
046e6604
 RUN cd helloflask-master && pip install -r requirements.txt
15612322
 ```
 
78c02d03
 Note that Docker doesn't care *how* dependencies are built - as long
 as they can be built by running a Unix command in a container.
5e2cec7b
 
 
6679f3b0
 Getting started
 ===============
cc3fece3
 
32402a7b
 Docker can be installed either on your computer for building applications or
 on servers for running them. To get started, [check out the installation
 instructions in the
 documentation](https://docs.docker.com/engine/installation/).
7009d6c6
 
787d774a
 We also offer an [interactive tutorial](https://www.docker.com/tryit/)
d4ec4d6e
 for quickly learning the basics of using Docker.
3ae5c45d
 
6679f3b0
 Usage examples
 ==============
d614e91b
 
046e6604
 Docker can be used to run short-lived commands, long-running daemons
f9d323d7
 (app servers, databases, etc.), interactive shell sessions, etc.
d614e91b
 
046e6604
 You can find a [list of real-world
85599338
 examples](https://docs.docker.com/engine/examples/) in the
046e6604
 documentation.
d614e91b
 
d49a2730
 Under the hood
 --------------
 
 Under the hood, Docker is built on the following components:
 
78c02d03
 * The
596836e0
   [cgroups](https://www.kernel.org/doc/Documentation/cgroup-v1/cgroups.txt)
78c02d03
   and
7e309aed
   [namespaces](http://man7.org/linux/man-pages/man7/namespaces.7.html)
bfddad18
   capabilities of the Linux kernel
787d774a
 * The [Go](https://golang.org) programming language
bfddad18
 * The [Docker Image Specification](https://github.com/docker/docker/blob/master/image/spec/v1.md)
011b4ca2
 * The [Libcontainer Specification](https://github.com/opencontainers/runc/blob/master/libcontainer/SPEC.md)
d49a2730
 
10005433
 Contributing to Docker [![GoDoc](https://godoc.org/github.com/docker/docker?status.svg)](https://godoc.org/github.com/docker/docker)
1480bff3
 ======================
 
10005433
 | **Master** (Linux) | **Experimental** (linux) | **Windows** | **FreeBSD** |
 |------------------|----------------------|---------|---------|
 | [![Jenkins Build Status](https://jenkins.dockerproject.org/view/Docker/job/Docker%20Master/badge/icon)](https://jenkins.dockerproject.org/view/Docker/job/Docker%20Master/) | [![Jenkins Build Status](https://jenkins.dockerproject.org/view/Docker/job/Docker%20Master%20%28experimental%29/badge/icon)](https://jenkins.dockerproject.org/view/Docker/job/Docker%20Master%20%28experimental%29/) | [![Build Status](http://jenkins.dockerproject.org/job/Docker%20Master%20(windows)/badge/icon)](http://jenkins.dockerproject.org/job/Docker%20Master%20(windows)/) | [![Build Status](http://jenkins.dockerproject.org/job/Docker%20Master%20(freebsd)/badge/icon)](http://jenkins.dockerproject.org/job/Docker%20Master%20(freebsd)/) |
7cb68713
 
99a5da5a
 Want to hack on Docker? Awesome! We have [instructions to help you get
85599338
 started contributing code or documentation](https://docs.docker.com/opensource/project/who-written-for/).
1480bff3
 
ca088572
 These instructions are probably not perfect, please let us know if anything
99a5da5a
 feels wrong or incomplete. Better yet, submit a PR and improve them yourself.
1480bff3
 
933f207f
 Getting the development builds
 ==============================
 
29ed8a22
 Want to run Docker from a master build? You can download 
7943bce8
 master builds at [master.dockerproject.org](https://master.dockerproject.org). 
1b104ce7
 They are updated with each commit merged into the master branch.
 
4374d3bc
 Don't know how to use that super cool new feature in the master build? Check
 out the master docs at
7943bce8
 [docs.master.dockerproject.org](http://docs.master.dockerproject.org).
4374d3bc
 
77f840fb
 How the project is run
 ======================
 
 Docker is a very, very active project. If you want to learn more about how it is run,
267b56bd
 or want to get more involved, the best place to start is [the project directory](https://github.com/docker/docker/tree/master/project).
77f840fb
 
 We are always open to suggestions on process improvements, and are always looking for more maintainers.
 
cb4d47dd
 ### Talking to other Docker users and contributors
 
 <table class="tg">
   <col width="45%">
   <col width="65%">
   <tr>
     <td>Internet&nbsp;Relay&nbsp;Chat&nbsp;(IRC)</td>
     <td>
       <p>
765880a4
         IRC is a direct line to our most knowledgeable Docker users; we have
cb4d47dd
         both the  <code>#docker</code> and <code>#docker-dev</code> group on
         <strong>irc.freenode.net</strong>.
         IRC is a rich chat protocol but it can overwhelm new users. You can search
         <a href="https://botbot.me/freenode/docker/#" target="_blank">our chat archives</a>.
       </p>
       Read our <a href="https://docs.docker.com/project/get-help/#irc-quickstart" target="_blank">IRC quickstart guide</a> for an easy way to get started.
     </td>
   </tr>
   <tr>
     <td>Google Groups</td>
     <td>
       There are two groups.
       <a href="https://groups.google.com/forum/#!forum/docker-user" target="_blank">Docker-user</a>
       is for people using Docker containers.
       The <a href="https://groups.google.com/forum/#!forum/docker-dev" target="_blank">docker-dev</a>
       group is for contributors and other people contributing to the Docker
       project.
e3e18584
       You can join them without an google account by sending an email to e.g. "docker-user+subscribe@googlegroups.com".
       After receiving the join-request message, you can simply reply to that to confirm the subscribtion.
cb4d47dd
     </td>
   </tr>
   <tr>
     <td>Twitter</td>
     <td>
       You can follow <a href="https://twitter.com/docker/" target="_blank">Docker's Twitter feed</a>
       to get updates on our products. You can also tweet us questions or just
       share blogs or stories.
     </td>
   </tr>
   <tr>
     <td>Stack Overflow</td>
     <td>
dae50f9b
       Stack Overflow has over 7000 Docker questions listed. We regularly
cb4d47dd
       monitor <a href="https://stackoverflow.com/search?tab=newest&q=docker" target="_blank">Docker questions</a>
       and so do many other knowledgeable Docker users.
     </td>
   </tr>
 </table>
 
da937bf2
 ### Legal
 
0a35b1fb
 *Brought to you courtesy of our legal counsel. For more context,
d94e1864
 please see the [NOTICE](https://github.com/docker/docker/blob/master/NOTICE) document in this repo.*
0a35b1fb
 
01dd7e74
 Use and transfer of Docker may be subject to certain restrictions by the
f9d323d7
 United States and other governments.
 
01dd7e74
 It is your responsibility to ensure that your use and/or transfer does not
f9d323d7
 violate applicable laws.
711e29fb
 
787d774a
 For more information, please see https://www.bis.doc.gov
a4a02358
 
 
 Licensing
 =========
522e6310
 Docker is licensed under the Apache License, Version 2.0. See
 [LICENSE](https://github.com/docker/docker/blob/master/LICENSE) for the full
 license text.
a4a02358
 
cd9ad8d5
 Other Docker Related Projects
 =============================
4669d98b
 There are a number of projects under development that are based on Docker's
5ad41ce0
 core technology. These projects expand the tooling built around the
f9d323d7
 Docker platform to broaden its application and utility.
99a5da5a
 
b4ebcdef
 * [Docker Registry](https://github.com/docker/distribution): Registry 
 server for Docker (hosting/delivery of repositories and images)
cd9ad8d5
 * [Docker Machine](https://github.com/docker/machine): Machine management 
f9d323d7
 for a container-centric world
cd9ad8d5
 * [Docker Swarm](https://github.com/docker/swarm): A Docker-native clustering 
f9d323d7
 system
a6824ea7
 * [Docker Compose](https://github.com/docker/compose) (formerly Fig): 
 Define and run multi-container apps
85599338
 * [Kitematic](https://github.com/docker/kitematic): The easiest way to use 
1b3bde47
 Docker on Mac and Windows
cd9ad8d5
 
7bd250c7
 If you know of another project underway that should be listed here, please help 
 us keep this list up-to-date by submitting a PR.
c7ab9b4a
 
 Awesome-Docker
 ==============
 You can find more projects, tools and articles related to Docker on the [awesome-docker list](https://github.com/veggiemonk/awesome-docker). Add your project there.