manifesto.rst 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. :title: Manifesto
  2. :description: An overview of Docker and standard containers
  3. :keywords: containers, lxc, concepts, explanation
  4. .. _dockermanifesto:
  5. *(This was our original Welcome page, but it is a bit forward-looking
  6. for docs, and maybe not enough vision for a true manifesto. We'll
  7. reveal more vision in the future to make it more Manifesto-y.)*
  8. Docker Manifesto
  9. ----------------
  10. Docker complements LXC with a high-level API which operates at the
  11. process level. It runs unix processes with strong guarantees of
  12. isolation and repeatability across servers.
  13. Docker is a great building block for automating distributed systems:
  14. large-scale web deployments, database clusters, continuous deployment
  15. systems, private PaaS, service-oriented architectures, etc.
  16. - **Heterogeneous payloads** Any combination of binaries, libraries,
  17. configuration files, scripts, virtualenvs, jars, gems, tarballs, you
  18. name it. No more juggling between domain-specific tools. Docker can
  19. deploy and run them all.
  20. - **Any server** Docker can run on any x64 machine with a modern linux
  21. kernel - whether it's a laptop, a bare metal server or a VM. This
  22. makes it perfect for multi-cloud deployments.
  23. - **Isolation** docker isolates processes from each other and from the
  24. underlying host, using lightweight containers.
  25. - **Repeatability** Because containers are isolated in their own
  26. filesystem, they behave the same regardless of where, when, and
  27. alongside what they run.
  28. .. image:: images/lego_docker.jpg
  29. What is a Standard Container?
  30. .............................
  31. Docker defines a unit of software delivery called a Standard
  32. Container. The goal of a Standard Container is to encapsulate a
  33. software component and all its dependencies in a format that is
  34. self-describing and portable, so that any compliant runtime can run it
  35. without extra dependency, regardless of the underlying machine and the
  36. contents of the container.
  37. The spec for Standard Containers is currently work in progress, but it
  38. is very straightforward. It mostly defines 1) an image format, 2) a
  39. set of standard operations, and 3) an execution environment.
  40. A great analogy for this is the shipping container. Just like Standard
  41. Containers are a fundamental unit of software delivery, shipping
  42. containers (http://bricks.argz.com/ins/7823-1/12) are a fundamental
  43. unit of physical delivery.
  44. Standard operations
  45. ~~~~~~~~~~~~~~~~~~~
  46. Just like shipping containers, Standard Containers define a set of
  47. STANDARD OPERATIONS. Shipping containers can be lifted, stacked,
  48. locked, loaded, unloaded and labelled. Similarly, standard containers
  49. can be started, stopped, copied, snapshotted, downloaded, uploaded and
  50. tagged.
  51. Content-agnostic
  52. ~~~~~~~~~~~~~~~~~~~
  53. Just like shipping containers, Standard Containers are
  54. CONTENT-AGNOSTIC: all standard operations have the same effect
  55. regardless of the contents. A shipping container will be stacked in
  56. exactly the same way whether it contains Vietnamese powder coffee or
  57. spare Maserati parts. Similarly, Standard Containers are started or
  58. uploaded in the same way whether they contain a postgres database, a
  59. php application with its dependencies and application server, or Java
  60. build artifacts.
  61. Infrastructure-agnostic
  62. ~~~~~~~~~~~~~~~~~~~~~~~~~~
  63. Both types of containers are INFRASTRUCTURE-AGNOSTIC: they can be
  64. transported to thousands of facilities around the world, and
  65. manipulated by a wide variety of equipment. A shipping container can
  66. be packed in a factory in Ukraine, transported by truck to the nearest
  67. routing center, stacked onto a train, loaded into a German boat by an
  68. Australian-built crane, stored in a warehouse at a US facility,
  69. etc. Similarly, a standard container can be bundled on my laptop,
  70. uploaded to S3, downloaded, run and snapshotted by a build server at
  71. Equinix in Virginia, uploaded to 10 staging servers in a home-made
  72. Openstack cluster, then sent to 30 production instances across 3 EC2
  73. regions.
  74. Designed for automation
  75. ~~~~~~~~~~~~~~~~~~~~~~~~~~
  76. Because they offer the same standard operations regardless of content
  77. and infrastructure, Standard Containers, just like their physical
  78. counterpart, are extremely well-suited for automation. In fact, you
  79. could say automation is their secret weapon.
  80. Many things that once required time-consuming and error-prone human
  81. effort can now be programmed. Before shipping containers, a bag of
  82. powder coffee was hauled, dragged, dropped, rolled and stacked by 10
  83. different people in 10 different locations by the time it reached its
  84. destination. 1 out of 50 disappeared. 1 out of 20 was damaged. The
  85. process was slow, inefficient and cost a fortune - and was entirely
  86. different depending on the facility and the type of goods.
  87. Similarly, before Standard Containers, by the time a software
  88. component ran in production, it had been individually built,
  89. configured, bundled, documented, patched, vendored, templated, tweaked
  90. and instrumented by 10 different people on 10 different
  91. computers. Builds failed, libraries conflicted, mirrors crashed,
  92. post-it notes were lost, logs were misplaced, cluster updates were
  93. half-broken. The process was slow, inefficient and cost a fortune -
  94. and was entirely different depending on the language and
  95. infrastructure provider.
  96. Industrial-grade delivery
  97. ~~~~~~~~~~~~~~~~~~~~~~~~~~
  98. There are 17 million shipping containers in existence, packed with
  99. every physical good imaginable. Every single one of them can be loaded
  100. on the same boats, by the same cranes, in the same facilities, and
  101. sent anywhere in the World with incredible efficiency. It is
  102. embarrassing to think that a 30 ton shipment of coffee can safely
  103. travel half-way across the World in *less time* than it takes a
  104. software team to deliver its code from one datacenter to another
  105. sitting 10 miles away.
  106. With Standard Containers we can put an end to that embarrassment, by
  107. making INDUSTRIAL-GRADE DELIVERY of software a reality.
  108. Standard Container Specification
  109. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  110. (TODO)
  111. Image format
  112. ~~~~~~~~~~~~
  113. Standard operations
  114. ~~~~~~~~~~~~~~~~~~~
  115. - Copy
  116. - Run
  117. - Stop
  118. - Wait
  119. - Commit
  120. - Attach standard streams
  121. - List filesystem changes
  122. - ...
  123. Execution environment
  124. ~~~~~~~~~~~~~~~~~~~~~
  125. Root filesystem
  126. ^^^^^^^^^^^^^^^
  127. Environment variables
  128. ^^^^^^^^^^^^^^^^^^^^^
  129. Process arguments
  130. ^^^^^^^^^^^^^^^^^
  131. Networking
  132. ^^^^^^^^^^
  133. Process namespacing
  134. ^^^^^^^^^^^^^^^^^^^
  135. Resource limits
  136. ^^^^^^^^^^^^^^^
  137. Process monitoring
  138. ^^^^^^^^^^^^^^^^^^
  139. Logging
  140. ^^^^^^^
  141. Signals
  142. ^^^^^^^
  143. Pseudo-terminal allocation
  144. ^^^^^^^^^^^^^^^^^^^^^^^^^^
  145. Security
  146. ^^^^^^^^