Docker基础之一: Docker架构

简介: Docker的架构 Docker使用的是 C-S架构。Docker的客户端同Docker Daemon进行交互,其中主要的工作是通过 daemon来完成,包括拉取镜像,编译镜像,运行容器,发布容器等。Docker client和daemon可以运行在同一个系统上,也可以通过远程方式进行访问。Doc

Docker的架构

Docker使用的是 C-S架构。Docker的客户端同Docker Daemon进行交互,其中主要的工作是通过 daemon来完成,包括拉取镜像,编译镜像,运行容器,发布容器等。Docker client和daemon可以运行在同一个系统上,也可以通过远程方式进行访问。Docker client和daemon之间是在 socket 上通过RESTful API来进行交互的。 

574478332a680c4ea8c3cf1a57fee4f5f6c217aa

Docker Daemon

如上图所示,Docker daemon运行在一个主机之上,用户并不是直接同daemon进行交互,而是通过Docker client来进行访问。

Docker Client

在Docker那个方框中,是主要的用户访问Docker的渠道。用户通过它对Docker Daemon进行访问控制。

Docker Images

Docker Image是一个只读的模板。比如,一个Image可以包含一个Ubuntu操作系统,整个系统可以包括Apache和你的web应用。Image是用来创建容器的。Docker提供了一种简单的方式来创建Image和更新已有的 Image, 你可以从网上下载Image,也可以自己编译Image。

Docker Registry

Docker Registry 是存放Image的仓库。我们可以使用公有的和私有的Registry来进行下载和上载。公共的Docker Registry位于Docker Hub,但是国内访问比较慢。Docker Hub包含了大量已有的Image,供用户使用。你可以基于之前的Image来创建自己的 Image。

Docker Containers

Docker容器就像一个文件夹。一个容器包含了应用程序运行所需的所有环境。每个容器都源于某一个Docker Image。Docker容器可以运行,开始,停止,移动并删除。每个容器都是完全隔离的和安全的应用。

Docker 如何工作

通过之前的介绍,我们知道:

  1. 我们可以自己编译Docker Image来打包应用
  2. 我们可以从Docker Image创建容器,并在其中运行应用程序
  3. 我们可以通过Docker Hub或私有的Registry来分享Docker Image 接下来,我们来看如何将之前的这些元素整合起来运行。

Docker Image 工作方式

我们已经看到Docker Image 是只读的模板,并随容器一起启动。每个Image包含了多个层。Docker Image使用的是Union File System来将这些层组合成一个Image。Union File System可以将文件和目录(通常称作Branch)进行透明的层叠组装,然后形成一个单独的文件系统。 Docker为什么轻量,就是因为使用了这些层状的文件系统。当用户修改一个Docker Image的时候(比如更新应用程序)一个新的层就会被建立。因此,这是一种增量式的修改,而不是新建一个全新的Image,这也是区别于传统虚拟机的一点。当你发布一个新的Image时,你只需要发布差异的部分,因此速度就非常快。
每个Image都来自于一个最基础的Image,如:ubuntu是一个基础Image,fedora是一个基础image。你也可以使用自己的Image作为基础Image,比如你可以创建包含了一个Apache 服务器的Image,作为所有web应用的基础Image。

注意:Docker通常从Docker Hub获取基础镜像。

Docker的Image都是从这些基础镜像衍生而来的,在编译Image是由一系列指令组成的,每个指令在我们的Image上创建一个新的曾。指令包括:

  • 执行一条命令
  • 添加文件或文件夹
  • 创建环境变量
  • 容器启动时,运行什么程序

Docker Registry 工作方式

Docker Registry是Image的仓库,当你编译完成一个Image时,你可以推送到公共的Registry,比如Docker Hub,也可以推送到你自己的私有Registry。 使用Docker Client,你可以搜索已经发布的Image,并从中拉取Image到本地,并在容器中运行。
Docker Hub提供了公有和私有的Registry。所有人都可以搜索和下载公共镜像。私有仓库只有私有用户能够查询和下载。

容器工作方式

一个容器由操作系统,用户文件和元数据构成。如我们所见,每个容器都根据镜像来生成。这个镜像告诉Docker 容器包含什么内容,运行什么程序,以及其他配置信息。Docker Image是只读的,当一个容器运行一个Image的时候,容器会在union FS的顶层增加文件层。

假如我们运行下面一条指令:

root@gctest:~# docker run -i -t ubuntu /bin/bash
Unable to find image 'ubuntu:latest' locally
latest: Pulling from library/ubuntu
Digest: sha256:f91f9bab1fe6d0db0bfecc751d127a29d36e85483b1c68e69a246cf1df9b4251
Status: Downloaded newer image for ubuntu:latest
root@ea7ffc10c7e7:/#

我们来做一下拆解,Docker Client通过run命令告诉Daemon启动一个新的容器。这个指令至少需要包括:

  • 需要运行什么Image,这里我们使用的是Ubuntu基础镜像
  • 需要在容器启动时,运行什么命令,这里我们使用的是/bin/bash 是否需要进入应用程序,这里我们指定的是-i -t,就是进入容器交互模式

那么具体到内部的流程是怎么样的呢?

  • 拉取ubuntu镜像:Docker检查本地是否有ubuntu镜像,如果不存在就自动从Docker Hub拉取。如果存在就进入下一步
  • 创建一个容器:一旦本地存在ubuntu 镜像,Docker将通过它来创建容器
  • 分配文件系统并mount 一个RW层:容器是创建在文件系统中的,并且在其之上增加了一层读写层。由此可以看出容器,并不会改变原始的镜像。
  • 分配网络/桥接模式:创建一个桥接网络接口,使容器可以和本地主机进行通信。
  • 设置一个IP地址:根据本地网络情况,选取一个可用的IP挂载到容器之上
  • 启动一个进程:这里就是/bin/bash
  • 抓取应用程序的输出:将程序的stdin, stdout和stderr,进行捕捉,这样我们可以看到程序的运行情况。 至此,你就拥有了一个运行的容器。通过容器,你可以运行程序,并且进行交互,当程序执行完毕,你可以停止和删除程序。

底层的技术

Docker是用Go编写的,同时使用了多种内核的功能来实现我们现在所看到的功能。

Namespaces

Docker 使用了Namespace这项技术来隔离工作区,也就是我们所说的容器。当容器运行时,Docker创建了一系列的Namespace。 通过Namespaces,容器运行在它自己的独立命名空间之中,而外层没有访问权限。目前,Docker使用了以下Namespace:

  • pid namespace: 用于进程的隔离(PID: Process ID)
  • net namespace: 用于管理网络接口x(NET: Networking)
  • ipc namespace: 用于管理进程间通讯(IPC: Inter Process Communication)
  • mnt namespace: 用于管理Mount点(MNT: Mount)
  • uts namespace: 用于隔离内核和版本信息(UTS: Unix Timesharing System)

Control Groups

Docker也使用了cgroups这项内核技术,通过cgroups可以限制应用程序使用的资源,这项技术可以使用户主机更好的运行多个容器而相互间不受影响。Cgroups可以限定容器使用的硬件资源,比如内存数量,CPU数量等。

Union File System

UnionFS用来对文件系统进行分层,通过分层可以使镜像更加轻量级和快速。Docker可以使用多种不同的UnionFS,比如AUFS, btrfs, vfs, DeviceMapper等。

容器格式

Docker将上述的多项技术包装在一起,形成了容器的格式。默认的容器格式是libcontainer , Docker也支持传统的 LXC格式。在未来,Docker也许会支持其他的容器格式,比如BSD Jails 或Solaris Zones.


备注:对有兴趣的朋友可以加我的微信ghostcloud2016,然后我把你加到我们的一个Docker爱好者群组里面。

目录
相关文章
|
27天前
|
Kubernetes 开发者 Docker
构建高效微服务架构:Docker与Kubernetes的完美搭档
【2月更文挑战第29天】在当今快速发展的软件开发领域,微服务架构已成为提高系统可维护性、扩展性和敏捷性的关键解决方案。本文将深入探讨如何利用Docker容器化技术和Kubernetes集群管理工具,共同构建一个既高效又可靠的微服务环境。我们将分析Docker和Kubernetes的核心功能,并展示它们如何协同工作以简化部署流程、增强服务发现机制以及实现无缝的服务伸缩。通过实际案例分析,本文旨在为开发者提供一套实用的微服务架构设计和实施指南。
|
2月前
|
KVM 虚拟化 Android开发
DP读书:鲲鹏处理器 架构与编程(十二)鲲鹏软件实战案例Docker+KVM的部署
DP读书:鲲鹏处理器 架构与编程(十二)鲲鹏软件实战案例Docker+KVM的部署
51 1
|
2月前
|
开发者 Docker 微服务
深入浅出:使用Docker容器化部署微服务架构
在当今快速迭代的软件开发环境中,微服务架构因其高度解耦和独立性而成为企业首选。然而,微服务的管理和部署可能会变得复杂和繁琐。本文将探讨如何利用Docker,一个轻量级的容器化技术,来简化和加速微服务的部署。我们将从Docker的基础概念入手,详细介绍如何创建、配置和运行微服务容器,最后讨论Docker在微服务架构中的优势和挑战。本文旨在为开发者提供一条清晰的路径,通过容器化技术实现微服务架构的高效部署和管理。
83 0
|
2月前
|
Kubernetes 开发者 Docker
深入浅出:使用Docker容器化部署微服务架构
在当今快速演进的软件开发领域,微服务架构因其高度的模块化和可伸缩性而受到广泛欢迎。然而,微服务的部署和管理也带来了新的挑战。本文旨在通过深入浅出的方式,探讨如何利用Docker容器技术有效地部署和管理微服务架构。我们将从Docker的基本概念出发,逐步深入到如何构建、部署微服务,并讨论在此过程中可能遇到的常见问题及其解决策略。本文不仅适合刚接触Docker和微服务的新手,也为有经验的开发者提供了实用的参考。
55 1
|
2月前
|
JSON JavaScript Docker
深入浅出:使用Docker容器化部署微服务架构
本文旨在向读者展示如何利用Docker技术高效地构建和部署微服务架构。通过深入浅出的方式,我们将探索Docker的基本概念、容器化的优势以及如何将其应用于微服务架构中。此外,文章还将提供一个简单的示例,指导读者实践如何使用Docker将一个现有的后端应用容器化,并部署到本地开发环境中。不同于传统的摘要,这里我们强调实践操作的重要性,鼓励读者通过实际操作来加深对Docker和微服务架构的理解。
51 1
|
2月前
|
Java 开发者 Docker
深入浅出:使用Docker容器化部署微服务架构
在本文中,我们将探索Docker容器技术如何革新微服务架构的部署方式,提高开发效率和应用的可扩展性。不同于传统摘要的概述风格,我们将通过一个实际案例,步骤明晰地展示如何将一个简单的微服务应用容器化,并在Docker环境中部署运行。本文旨在为开发者提供一个清晰、易懂的指南,帮助他们理解容器化技术的基本原理和操作流程,无论是初学者还是有经验的开发人员都能从中获益。
|
2月前
|
存储 Kubernetes Docker
深入浅出:使用Docker容器化部署微服务架构
在当今快速迭代的软件开发周期中,微服务架构凭借其高度的模块化和灵活性成为了众多企业的首选。然而,随之而来的是对环境一致性和服务部署效率的挑战。本文将探讨如何利用Docker这一轻量级容器技术,实现微服务的快速、一致和可靠部署。通过深入浅出的方式,我们将介绍Docker的基本概念、容器化微服务的优势以及步骤详解,旨在为读者提供一个清晰的实践指南,帮助他们在微服务架构的部署过程中提升效率和可靠性。
65 0
|
2月前
|
设计模式 运维 Docker
深入浅出:使用Docker容器化部署微服务架构
本文旨在为读者提供一个全面且易于理解的指南,介绍如何使用Docker技术来容器化部署微服务架构。随着云计算和微服务架构的普及,Docker作为一种轻量级的容器解决方案,已经成为开发和运维领域的热门技术。本文将从Docker的基本概念出发,详细讲解如何将传统的应用服务转化为容器化的微服务,包括Dockerfile的编写、镜像构建、容器部署以及服务编排等关键步骤。此外,文章还会探讨使用Docker部署微服务架构的最佳实践和常见问题,帮助读者有效地管理和优化其微服务系统。
64 1
|
2月前
|
Kubernetes API Docker
深入浅出:使用Docker容器化部署微服务架构
在本文中,我们将探索如何利用Docker容器技术实现微服务架构的高效部署与管理。不同于传统的摘要方式,我们将采用一个故事化的场景引入,设想在一个快速发展的互联网公司中,随着业务的扩张,传统的单体应用逐渐变得难以维护和扩展。开发团队决定采用微服务架构来解决这一问题,而Docker作为容器化技术的佼佼者,被选为部署和管理微服务的关键工具。文章将详细介绍Docker的基本概念、微服务架构的优势,以及如何结合两者进行高效的应用部署和管理。
24 0
|
2月前
|
存储 运维 Docker
深入浅出:使用Docker容器化部署微服务架构
在快速迭代和高效部署的今天,Docker作为一种轻量级的容器化技术,已经成为开发和运维领域的热门话题。本文将从容器化技术的基础出发,详细介绍如何使用Docker来容器化部署微服务架构。我们不仅会探讨Docker的基本概念、核心优势以及与传统虚拟化技术的区别,还将通过一个实际的微服务应用示例,指导读者如何构建、部署并管理Docker容器。此外,文章还将涉及Docker Compose工具的使用,以简化多容器应用的管理。无论你是开发人员还是运维工程师,本文都将为你提供一条清晰的学习路径,助你掌握使用Docker容器化部署微服务架构的关键技能。