From 97d8e43b4900d5ffacda711c7cb82190a04db670 Mon Sep 17 00:00:00 2001 From: Tao Wang Date: Mon, 7 Nov 2016 07:00:17 +1100 Subject: [PATCH] =?UTF-8?q?=E6=89=A9=E5=B1=95=20"=E4=B8=BA=E4=BB=80?= =?UTF-8?q?=E4=B9=88=E8=A6=81=E4=BD=BF=E7=94=A8=20Docker"=20=E6=96=87?= =?UTF-8?q?=E6=A1=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 让文档更结构化,并且调整补充更多的信息 --- introduction/why.md | 37 ++++++++++++++++++++----------------- 1 file changed, 20 insertions(+), 17 deletions(-) diff --git a/introduction/why.md b/introduction/why.md index f852f4f..594f20c 100644 --- a/introduction/why.md +++ b/introduction/why.md @@ -1,30 +1,34 @@ ## 为什么要使用 Docker? + 作为一种新兴的虚拟化方式,Docker 跟传统的虚拟化方式相比具有众多的优势。 -首先,Docker 容器的启动可以在秒级实现,这相比传统的虚拟机方式要快得多。 -其次,Docker 对系统资源的利用率很高,一台主机上可以同时运行数千个 Docker 容器。 +### 更高效的利用系统资源 -容器除了运行其中应用外,基本不消耗额外的系统资源,使得应用的性能很高,同时系统的开销尽量小。传统虚拟机方式运行 10 个不同的应用就要起 10 个虚拟机,而Docker 只需要启动 10 个隔离的应用即可。 +由于容器不需要进行硬件虚拟以及运行完整操作系统等额外开销,Docker 对系统资源的利用率更高。无论是应用执行速度、内存损耗或者文件存储速度,都要比传统虚拟机技术更高效。因此,相比虚拟机技术,一个相同配置的主机,往往可以运行更多数量的应用。 -具体说来,Docker 在如下几个方面具有较大的优势。 +### 更快速的启动时间 -### 更快速的交付和部署 -对开发和运维(devop)人员来说,最希望的就是一次创建或配置,可以在任意地方正常运行。 +传统的虚拟机技术启动应用服务往往需要数分钟,而 Docker 容器应用,由于直接运行于宿主内核,无需启动完整的操作系统,因此可以做到秒级、甚至毫秒级的启动时间。大大的节约了开发、测试、部署的时间。 -开发者可以使用一个标准的镜像来构建一套开发容器,开发完成之后,运维人员可以直接使用这个容器来部署代码。 -Docker 可以快速创建容器,快速迭代应用程序,并让整个过程全程可见,使团队中的其他成员更容易理解应用程序是如何创建和工作的。 -Docker 容器很轻很快!容器的启动时间是秒级的,大量地节约开发、测试、部署的时间。 +### 一致的运行环境 -### 更高效的虚拟化 -Docker 容器的运行不需要额外的 hypervisor 支持,它是内核级的虚拟化,因此可以实现更高的性能和效率。 +开发过程中一个常见的问题是环境一致性问题。由于开发环境、测试环境、生产环境不一致,导致有些 bug 并未在开发过程中被发现。而 Docker 的镜像提供了除内核外完整的运行时环境,确保了应用运行环境一致性,从而不会再出现 *“这段代码在我机器上没问题啊”* 这类问题。 -### 更轻松的迁移和扩展 +### 持续交付和部署 -Docker 容器几乎可以在任意的平台上运行,包括物理机、虚拟机、公有云、私有云、个人电脑、服务器等。 -这种兼容性可以让用户把一个应用程序从一个平台直接迁移到另外一个。 +对开发和运维([DevOps](https://zh.wikipedia.org/wiki/DevOps))人员来说,最希望的就是一次创建或配置,可以在任意地方正常运行。 -### 更简单的管理 -使用 Docker,只需要小小的修改,就可以替代以往大量的更新工作。所有的修改都以增量的方式被分发和更新,从而实现自动化并且高效的管理。 +使用 Docker 可以通过定制应用镜像来实现持续集成、持续交付、部署。开发人员可以通过 [Dockerfile](https://docs.docker.com/engine/reference/builder/) 来进行镜像构建,并结合 [持续集成(Continuous Integration)](https://en.wikipedia.org/wiki/Continuous_integration) 系统进行集成测试,而运维人员则可以直接在生产环境中快速部署该镜像,甚至结合 [持续部署(Continuous Delivery/Deployment)](https://en.wikipedia.org/wiki/Continuous_delivery) 系统进行自动部署。 + +而且使用 `Dockerfile` 使镜像构建透明化,不仅仅开发团队可以理解应用运行环境,也方便运维团队理解应用运行所需条件,帮助更好的生产环境中部署该镜像。 + +### 更轻松的迁移 + +由于 Docker 确保了执行环境的一致性,使得应用的迁移更加容易。Docker 可以在很多平台上运行,无论是物理机、虚拟机、公有云、私有云,甚至是笔记本,其运行结果是一致的。因此用户可以很轻易的将在一个平台上运行的应用,迁移到另一个平台上,而不用担心运行环境的变化导致应用无法正常运行的情况。 + +### 更轻松的维护和扩展 + +Docker 使用的分层存储以及镜像的技术,使得应用重复部分的复用更为容易,也使得应用的维护更新更加简单,基于基础镜像进一步扩展镜像也变得非常简单。此外,Docker 团队同各个开源项目团队一起维护了一大批高质量的[官方镜像](https://hub.docker.com/explore/),既可以直接在生产环境使用,又可以作为基础进一步定制,大大的降低了应用服务的镜像制作成本。 ### 对比传统虚拟机总结 @@ -34,4 +38,3 @@ Docker 容器几乎可以在任意的平台上运行,包括物理机、虚拟 | 硬盘使用 | 一般为 MB | 一般为 GB | | 性能 | 接近原生 | 弱于 | | 系统支持量 | 单机支持上千个容器 | 一般几十个 | -