manifesto.rst 5.6 KB

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