不会和容器一起启动_微服务中的容器技术Docker(二),Docker中的镜像分层

概述

经过上一篇之后,对Docker应该已经不陌生了。
上一篇传送门《微服务中的容器技术---Docker(一),Docker的安装和使用》

Docker镜像

那么我们应该知道镜像和容器该如何区分了,这里就更形象地说明一下:
Docker镜像是一个只读的Docker容器模板,含有启动Docker容器所需的文件系统结构及其内容,因此是启动一个Docker容器的基础。Docker镜像的文件内容以及一些运行Docker容器的配置文件组成了Docker容器的静态文件系统运行环境–rootfs。可以这么理解,Docker镜像是Docker容器的静态视角,Docker容器是Docker镜像的运行状态

f6baf6a4c0d69c0ce3b38970cf96d3be.png

Docker镜像

从上图可以看到,新镜像是从 base 镜像一层一层叠加生成的。每安装一个软件,就在现有镜像的基础上增加一层

  • 共享宿主机的Kernel

  • Base镜像提供的是最小的Linux发行版
    Docker 支持通过扩展现有镜像,创建新的镜像。实际上,Docker Hub 中 99% 的镜像都是通过在 base 镜像中安装和配置需要的软件构建出来的。

  • 同一Docker主机支持运行多种Linux发行版

  • 采用分层的最大好处: 共享资源

继续来看Docker的分层结构

f4b0639b4ca853bd7a59fc6cdb27f803.png

Docker容器层

当容器启动时,一个新的可写层被加载到镜像的顶部。这一层通常被称作“容器层”,“容器层”之下的都叫“镜像层”。

  • Copy-on-Write
    如果多个容器共享一份基础镜像,当某个容器修改了基础镜像的内容,比如 /etc 下的文件,这时其他容器的 /etc 是不会被修改的,修改只会被限制在单个容器内(详细见:展开说明)

  • 只有容器层是可写的,容器层下面的所有镜像层都是只读

  • Docker从上往下依次查找

  • 容器层保存镜像变化的部分,并不会对镜像本身做任何修改

  • 一个镜像最多127层

※展开说明:
镜像层数量可能会很多,所有镜像层会联合在一起组成一个统一的文件系统。如果不同层中有一个相同路径的文件,比如 /a,上层的 /a 会覆盖下层的 /a,也就是说用户只能访问到上层中的文件 /a。在容器层中,用户看到的是一个叠加之后的文件系统。

文件操作

00da5ef71377cc48bb0ee970fc768f83.png

只有当需要修改时才复制一份数据,这种特性被称作 Copy-on-Write。可见,容器层保存的是镜像变化的部分,不会对镜像本身进行任何修改。
这样就解释了我们前面提出的问题:容器层记录对镜像的修改,所有镜像层都是只读的,不会被容器修改,所以镜像可以被多个容器共享。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值