README.md
15612322
 Docker: the Linux container engine
 ==================================
0db56e6c
 
70ab25a5
 Docker is an open source project to pack, ship and run any application
 as a lightweight container
63ce0810
 
046e6604
 Docker containers are both *hardware-agnostic* and *platform-agnostic*.
 This means that they can run anywhere, from your laptop to the largest
 EC2 compute instance and everything in between - and they don't require
 that you use a particular language, framework or packaging system. That
 makes them great building blocks for deploying and scaling web apps,
 databases and backend services without depending on a particular stack
 or provider.
0db56e6c
 
78c02d03
 Docker is an open-source implementation of the deployment engine which
046e6604
 powers [dotCloud](http://dotcloud.com), a popular Platform-as-a-Service.
 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
 
cacb5c0d
 ![Docker L](docs/theme/mkdocs/images/docker-logo-compressed.png "Docker")
2ac7298e
 
9e2cc4fc
 ## Security Disclosure
 
d9d08c5e
 Security is very important to us.  If you have any issue regarding security, 
 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
046e6604
 VMWare's vmdk, Oracle Virtualbox's vdi, and Amazon EC2's ami. In theory
 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
 Linux with [openvz](http://openvz.org),
78c02d03
 [vserver](http://linux-vserver.org) and more recently
 [lxc](http://lxc.sourceforge.net), Solaris with
 [zones](http://docs.oracle.com/cd/E26502_01/html/E29024/preface-1.html#scrolltoc)
 and FreeBSD with
 [Jails](http://www.freebsd.org/doc/handbook/jails.html).
 
046e6604
 Docker builds on top of these low-level primitives to offer developers a
 portable format and runtime environment that solves all 4 problems.
 Docker containers are small (and their transfer can be optimized with
 layers), they have basically zero memory and cpu overhead, they are
 completely portable and are designed from the ground up with an
 application-centric design.
78c02d03
 
046e6604
 The best part: because Docker operates at the OS level, it can still be
 run inside a VM!
5e2cec7b
 
15612322
 ## Plays well with others
5e2cec7b
 
78c02d03
 Docker does not require that you 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.
 
   * Conflicting dependencies. Different applications may depend on
     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.
15612322
   
78c02d03
   * Custom dependencies. A developer may need to prepare a custom
     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
 
 
78c02d03
 Docker solves dependency hell by giving the developer a simple way to
 express *all* their application's dependencies in one place, and
 streamline the process of assembling them. If this makes you think of
 [XKCD 927](http://xkcd.com/927/), don't worry. Docker doesn't
 *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
 RUN apt-get update
 RUN apt-get install -q -y python python-pip curl
 RUN curl -L https://github.com/shykes/helloflask/archive/master.tar.gz | tar -xzv
 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
 
046e6604
 Docker can be installed on your local machine as well as servers - both
 bare metal and virtualized.  It is available as a binary on most modern
 Linux systems, or as a VM on Windows, Mac and other systems.
7009d6c6
 
d4ec4d6e
 We also offer an [interactive tutorial](http://www.docker.com/tryit/)
 for quickly learning the basics of using Docker.
3ae5c45d
 
d4ec4d6e
 For up-to-date install instructions, see the [Docs](http://docs.docker.com).
3ae5c45d
 
6679f3b0
 Usage examples
 ==============
d614e91b
 
046e6604
 Docker can be used to run short-lived commands, long-running daemons
 (app servers, databases etc.), interactive shell sessions, etc.
d614e91b
 
046e6604
 You can find a [list of real-world
 examples](http://docs.docker.io/en/latest/examples/) in the
 documentation.
d614e91b
 
d49a2730
 Under the hood
 --------------
 
 Under the hood, Docker is built on the following components:
 
78c02d03
 * The
   [cgroup](http://blog.dotcloud.com/kernel-secrets-from-the-paas-garage-part-24-c)
   and
   [namespacing](http://blog.dotcloud.com/under-the-hood-linux-kernels-on-dotcloud-part)
   capabilities of the Linux kernel;
046e6604
 * The [Go](http://golang.org) programming language.
d49a2730
 
1480bff3
 Contributing to Docker
 ======================
 
78c02d03
 Want to hack on Docker? Awesome! There are instructions to get you
f11fb706
 started [here](CONTRIBUTING.md).
1480bff3
 
78c02d03
 They are probably not perfect, please let us know if anything feels
 wrong or incomplete.
1480bff3
 
da937bf2
 ### Legal
 
0a35b1fb
 *Brought to you courtesy of our legal counsel. For more context,
 please see the Notice document.*
 
01dd7e74
 Use and transfer of Docker may be subject to certain restrictions by the
 United States and other governments.  
 It is your responsibility to ensure that your use and/or transfer does not
 violate applicable laws. 
711e29fb
 
b48fc965
 For more information, please see http://www.bis.doc.gov
a4a02358
 
 
 Licensing
 =========
 Docker is licensed under the Apache License, Version 2.0. See LICENSE for full license text.