Docker概念docker
Docker是开发人员和系统管理人员使用容器构建、共享和运行应用程序的一个平台。使用容器来部署应用程序的过程被称为容器化。图1.1形象地告诉咱们,您能够经过docker容器来轻松部署应用程序。安全
容器化部署愈来愈受欢迎,由于容器具备如下特征:运维
灵活(Flexible):即便是最复杂的应用程序也能够被容器化。ide
轻量级(Lightweight):容器利用并共享宿主机内核,这使它们在系统资源使用方面比虚拟机更高效。工具
可移植性(Protable):您能够在本地构建、部署到云,并在任何地方运行。操作系统
松耦合(Loosely coupled):容器是高度自给自足和封装的,容许您替换或升级一个容器,而不会中断其余容器。3d
可伸缩性(Scalable):您能够在数据中心增长并自动分发容器副本。对象
安全性(Secure):容器对进程应用有严格的约束和隔离,而不须要用户作任何配置。blog
图1.1生命周期
镜像和容器
从根本上说,容器就是一个正在运行的进程,它应用了一些附加的封装特性,以便将它与主机和其余容器隔离开来。容器隔离的一个最重要的方面是,每一个容器都与本身的私有文件系统交互;这个文件系统由Docker镜像提供。镜像包含运行应用程序所需的全部内容,如代码或二进制文件、runtimes、依赖项以及所需的任何其余文件系统对象。
容器和虚拟机
容器运行在本地(原生)Linux主机上,并与其余容器共享宿主机的内核。它运行一个离散的进程,占用的内存不比任何其余可执行文件多,所以它很轻量,如图1.2所示。
相比之下,虚拟机(VM)是一个完整的“guest”操做系统,经过hypervisor对主机资源进行访问,如图1.3所示。通常来讲,vm除了应用程序逻辑所消耗的开销以外,还会产生其余开销。
图1.2
图1.3
编排
容器的可移植性和可复制性意味着咱们可以在云和数据中心之间移动和扩展咱们的容器化应用;容器有效地保证了这些应用程序在任何地方都将以相同的方式运行,容许咱们快速轻松地利用全部这些环境。此外,随着应用程序规模的扩大,咱们须要一些工具来自动化运维这些应用程序,可以自动替换失败的容器,并管理这些容器,使容器在其生命周期中的一些更新和从新配置变得更加容易。
管理、扩展和维护容器化应用程序的工具被称为编排,其中最多见的编排工具就是Google的Kubernetes和Docker的Swarm。这两个编排工具在Docker Desktop中均有集成,咱们将在本指南中使用Docker Desktop建立第一个编排的容器化应用程序。
安装Docker Desktop
容器化应用开发的最佳实践就是使用Docker Desktop。Docker Desktop将容许您在本地开发机器上轻松配置Kubernetes或者Swarm,所以您能够当即使用编排工具的全部特性来开发您的应用,而且无需集群。
在Windows上安装Docker Desktop请参照下一篇“在Windows 10上安装Docker Desktop并启用Kubernetes"