『现学现忘』Docker基础 — 16、Docker中的基本概念和底层原理
Docker架构图:
我们依照Docker架构图进行Docker基础概念的说明。
1、Docker的底层原理
Docker是一个Client-Server
结构的系统,Docker守护进程运行在主机上,然后通过Socket
连接从客户端访问,守护进程从客户端接受命令并管理运行在主机上的容器。容器是一个运行时环境,就好比是我们前面说到的集装箱。
例如架构图中的客户端(Client
)和服务端(DOCKER_HOST
):
发送命令docker run hello-world
- Docker客户端转发命令给宿主机上的Docker守护进程(
Docker daemon
), - Docker守护进程接收执行命令,返回命令执行结果,
- Docker服务端(守护进程)负责管理宿主机上的各个容器。
如下图所示:
Docker客户端和守护进程通过Socket
连接,可以远程或本地连接。
Socket
说明:网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为一个
Socket
。建立网络通信连接至少要一对端口号(Socket
)。Socket
是应用层与TCP/IP
协议族通信的中间软件抽象层,它是用来组织数据的一组接口。
2、Docker中常用的基本概念
- 镜像(
image
):Docker镜像类似于虚拟机的镜像,就好比是一个模板,一个面向Docker引擎的只读模板,包含了文件系统,可以通过这个模板来创建容器服务。
例如:一个镜像可以完全包含了Ubuntu
操作系统环境,可以把它称作一个Ubuntu
镜像。镜像也可以安装了Apache
应用程序(或其他软件),可以把它称为一个Apache
镜像。通过这个镜像可以创建多个容器(最终服务的运行或者项目的运行就是在容器中)。
镜像是创建Docker容器的基础,通过版本管理和增量的文件系统,Docker提供了一套十分简单的机制来创建和更新现有的镜像。用户可以从网上下载一个已经做好的应用镜像,并通过命令直接使用。总之,应用运行是需要环境的,而镜像就是来提供这种环境。
(不同的类可以创建不同的对象,同一个类也可以创建多个相同类型的对象)
(不同的镜像可以创建不同的容器,同一个镜像也可以创建多个相同类型的容器) - 容器(
Container
):Docker利用容器技术,独立运行一个或者一组应用,通过镜像来创建的。
Docker容器类似于一个轻量级的沙箱子(因为Docker是基于Linux内核的虚拟技术,所以消耗资源十分少),Docker利用容器来运行和隔离应用。
容器是从镜像创建运行实例,可以将其启动、开始、停止、删除,而这些容器都是相互隔离、互不可见的。
镜像自身是只读的,容器从镜像启动的时候,Docker会在镜像的最上层创建一个可写层,镜像本身将保持不变。
(目前就可以把这容器解为就是一个简易的Linuх系统) - 仓库(
Repository
):仓库就是存放镜像的地方。
Docker仓库类似与代码仓库,就是Docker集中存放镜像文件的场所。
根据存储的镜像公开与否,Docker仓库分为公开仓库(Public
)和私有仓库(Private
)两种形式。
目前最大的公开仓库是Docker Hub
(Docker官方镜像仓库),存放了数量庞大的镜像供用户下载。国内的公开仓库包括阿里云,网易云等镜像仓库,可以提供稳定的国内访问(镜像加速)。
Docker也支持用户在本地网络内创建一个只能自己访问的私有仓库。
当用户创建了自己的镜像之后,就可以使用push
命令,将它上传到指定的公有或则私有仓库。这样用户下次在另一台机器上使用该镜像时,只需将该镜像从仓库pull
(拉取)下来就可以了。
镜像和容器的关系:
3、run命令的运行流程
我们以之前运行hello-world
镜像为例进行说明。
执行docker run hello-world
命令,运行结果如下:
$ sudo docker run hello-world
# 出现下面显示,证明运行镜像成功
Unable to find image 'hello-world:latest' locally #(本地没有找到hello-world镜像)
latest: Pulling(拉取) from library/hello-world #(去远程拉取library/hello-world镜像)
1b930d010525: Pull complete #(拉取完成)
Digest: sha256:d1668a9a1f5b42ed3f46b70b9cb7c88fd8bdc8a2d73509bb0041cf436018fbf5
Status: Downloaded newer image for hello-world:latest
#(上面三行是拉取镜像的签名信息)
# 总结:由于本地没有hello-world这个镜像,所以会从远程仓库下载一个hello-world的镜像到本地,并创建容器运行。
Hello from Docker!#(镜像运行起来了)
This message shows that your installation appears to be working correctly.
#(此消息表明您的安装似乎可以正常工作。为了生成此消息,Docker采取了以下步骤:)
To generate this message, Docker took the following steps:
1. The Docker client contacted the Docker daemon.
2. The Docker daemon pulled the "hello-world" image from the Docker Hub.
(amd64)
3. The Docker daemon created a new container from that image which runs the
executable that produces the output you are currently reading.
4. The Docker daemon streamed that output to the Docker client, which sent it
to your terminal.
To try something more ambitious, you can run an Ubuntu container with:
$ docker run -it ubuntu bash
Share images, automate workflows, and more with a free Docker ID:
https://hub.docker.com/
For more examples and ideas, visit:
https://docs.docker.com/get-started/
提示:输出这段提示以后,
hello-world
镜像就会停止运行,容器自动终止。
run
命令的执行的流程图:
4、为什么Docker比VM快
- (1)Docker有着比虚拟机更少的抽象层。
由于Docker不需要Hypervisor实现硬件资源虚拟化(就相当于使用VMware创建一个虚拟机的操作),运行在Docker容器上的程序,直接使用的都是实际物理机的硬件资源。因此在CPU、内存利用率上,Docker将会在效率上有明显优势。 - (2)Docker利用的是宿主机的内核,而不需要Guest OS。
因此当新建一个容器时,Docker不需要和虚拟机一样重新加载一个操作系统内核。从而避免引寻、加载操作系统内核等,这些比较费时费资源的操作过程。
当新建一个虚拟机时,虚拟机软件需要加载Guest OS,这个新建过程是分钟级别的。而Docker由于直接利用宿主机的操作系统,则省略了这个过程,因此新建一个Docker容器只需要几秒钟。
如下图所示:
Docker与VM对比表:
『现学现忘』Docker基础 — 16、Docker中的基本概念和底层原理的更多相关文章
- 『学了就忘』Linux基础 — 16、Linux系统与Windows系统的不同
目录 1.Linux严格区分大小写 2.Linux一切皆文件 3.Linux不靠扩展名区分文件类型 4.Linux中所有的存储设备都必须在挂载之后才能使用 5.Windows下的程序不能直接在Linu ...
- 『现学现忘』Docker基础 — 9、Docker简介
目录 1.什么是Docker? 2.Docker的出现解决了什么问题? 3.Docker的特别之处 4.Docker相关网站 1.什么是Docker? 2010年dotCloud公司在旧金山成立,PA ...
- 『现学现忘』Docker基础 — 25、Docker镜像讲解
目录 1.镜像是什么 2.Docker镜像获取的方式 3.Docker镜像加载原理 (1)UnionFS(联合文件系统) (2)Docker镜像加载原理 1.镜像是什么 镜像是一种轻量级.可执行的独立 ...
- 『现学现忘』Docker基础 — 26、Docker镜像分层的理解
目录 1.分层的镜像 2.加深理解 3.特别说明 1.分层的镜像 我们可以去下载一个镜像,注意观察下载的日志输出,可以看到Docker的镜像是一层一层的在下载. 思考:为什么Docker镜像要采用这种 ...
- 『现学现忘』Docker基础 — 34、DockerFile文件详解
目录 1.DockerFile文件说明 2.Dockerfile构建过程解析 (1)Docker容器构建三步骤 (2)Dockerfile文件的基本结构 (3)Dockerfile注意事项 (4)Do ...
- 『现学现忘』Docker基础 — 35、实战:自定义CentOS镜像
目录 1.前提说明 2.编写Dockerfile文件 3.构建镜像 4.运行镜像 5.列出镜像的变更历史 1)目标:自定义镜像wokong_centos. 2)所用到的保留字指令: FROM:基础镜像 ...
- 『现学现忘』Docker基础 — 10、Docker的安装
目录 1.前提 2.通过yum安装Docker (1)更新yum包 (2)移除旧的Docker版本 (3)安装必须的软件包 (4)设置稳定yum源仓库 (5)更新yum软件包索引 (6)开始安装Doc ...
- 『现学现忘』Docker基础 — 29、Docker容器数据卷的应用
目录 1.验证容器和宿主机之间数据共享 2.容器停止退出后,主机修改后数据是否同步 3.带只读权限的挂载数据卷 1.验证容器和宿主机之间数据共享 通过上面的操作,接下来我们演示一下通过数据卷的挂载,实 ...
- 『现学现忘』Docker基础 — 30、Docker中数据卷相关命令
目录 1.Volume命令说明 2.Volume命令的使用 (1)创建数据卷 (2)查看本地数据卷列表 (3)打印myVolume数据卷的详细信息 (4)删除数据卷 (5)删除所有未使用的数据卷 3. ...
随机推荐
- Java BigDecimal 的舍入模式(RoundingMode)详解
BigDecimal.divide方法中必须设置roundingMode,不然会报错. ROUND_UP:向正无穷方向对齐(转换为正无穷方向最接近的所需数值) ROUND_DOWN:向负无穷方向对齐 ...
- react组件中的类调用construcor、super方法你知道多少?
constructor:在类中作为一个钩子函数,有constructor钩子函数的时候,可以定义state,如果用户不定义state的话,有无constructor钩子函数没啥区别: super:
- CF954H Path Counting
一开始的想法是枚举路径的 \(\rm LCA\) 然后再枚举两边的深度,但是这样无论如何我都只能做到 \(O(n ^ 3)\) 的复杂度. 只能考虑换一种方式计数,注意到点分治可以解决树上一类路径问题 ...
- HTML图片轮播
一.纯 CSS 实现图片轮播 引自原文作者:南张人 原文链接:https://blog.csdn.net/u011848617/article/details/80468463 理论基础 CSS3 a ...
- JS 将Table内容导出到Excel(样式设计)
转载请注明来源:https://www.cnblogs.com/hookjc/ function saveAsExcel(tableID){ var tb = new TableToExcel(tab ...
- js 计算中英文混合字符串长度
转载请注明来源:https://www.cnblogs.com/hookjc/ function isChinese(str) { var lst = /[u00-uFF]/; ...
- 编译安装nginx,实现多域名 https
一.编译安装nginx 1.1 获取源码包 [root@cetnos7 ~]#wget -O /usr/local/src/nginx-1.18.0.tar.gz http://nginx.org/d ...
- Solution -「CF 1372E」Omkar and Last Floor
\(\mathcal{Description}\) Link. 给定一个 \(n \times m\) 的矩阵,每行被划分为若干段,你可以钦定每段中恰好一个位置为 \(1\),其余位置为 \( ...
- 自学linux(安装系统,图形化界面,安装chrome)STEP1
1. 下载虚拟机VMware并安装 破解版: https://www.xitmi.com/2417.html 2. 下载centos7,6据说已经找不到了? 阿里云镜像: https://mirror ...
- CentOS7下Jumpserver V3.0 部署
环境准备 # 准备一台 2核4G (最低)且可以访问互联网的 64 位 Centos 7 主机 [root@localhost ~]# hostnamectl --static set-hostnam ...