当前位置: 首页 > news >正文

docker容器的三大核心技术UnionFS(下)

2. OverlayFS 与 Overlay2
OverlayFS 是 Linux 内核 3.18 引入的内核级联合文件系统,直接基于内核实现,性能优于 AUFS;Overlay2 是 OverlayFS 的改进版,支持最多 128 个只读层,解决了 OverlayFS 分层数量限制的问题,成为 Docker 默认存储驱动。
(1)核心原理与分层结构
核心组件:
lowerdir:多个只读层的集合(对应 Docker 镜像层),优先级从左到右递减。
upperdir:可写层(对应 Docker 容器的可写层,存储容器运行时的修改)。
workdir:临时工作目录(用于 OverlayFS 内部操作,如文件重命名、复制,必须为空且独占)。
merged:统一挂载点(容器内看到的根文件系统视图)。
与 AUFS 的关键差异:
OverlayFS 原生支持 “1 个可写层 + N 个只读层”,Overlay2 通过嵌套叠加支持更多只读层(最多 128 层)。
依赖内核实现,无需用户态适配,IO 性能更高。
(2)实操示例:OverlayFS 挂载与验证
创建测试目录结构:
bash
mkdir overlay-test && cd overlay-test
mkdir layer1 layer2 upperlayer workdir mountedfs  # workdir 为临时工作目录
echo "content for file1 in layer1" > layer1/file1
echo "content for file1 in layer2" > layer2/file1
echo "content for file2 in layer1" > layer1/file2
echo "content for file3 in layer2" > layer2/file3
挂载 OverlayFS 文件系统:
bash
mount -t overlay -o lowerdir=layer1:layer2,upperdir=upperlayer,workdir=workdir overlay mountedfs
# 参数说明:-o 指定 lowerdir/upperdir/workdir 路径;overlay 为文件系统类型
验证核心特性:
读取 mountedfs/file1,返回 layer1 中的内容(左侧优先级更高)。
在 mountedfs 中修改 file1,实际修改的是 upperlayer/file1,layer1/file1 保持不变(写时复制)。
查看 workdir,会生成临时文件(用于 OverlayFS 内部处理,用户无需手动操作)。
(3)Docker 中 Overlay2 的实际应用
以 Alpine 镜像创建容器为例,验证 Overlay2 在 Docker 中的存储结构:
启动容器:
bash
docker run --name conoverlay --rm -id alpine ash  # 启动 Alpine 容器,容器 ID 假设为 6f8973ac28d6
查看 Overlay2 挂载信息:
bash
# 查看容器对应的 Overlay2 挂载点
mount | grep overlay
# 输出示例(关键路径解析):
# overlay on /var/lib/docker/overlay2/<mount-id>/merged type overlay(...)
# - <mount-id>:随机 ID,对应容器的 Overlay2 存储目录
# - merged:容器根文件系统的挂载点(统一视图)
# - lowerdir:镜像只读层路径;upperdir:容器可写层路径;workdir:临时工作目录
定位容器存储目录:
Docker 为每个容器在 /var/lib/docker/image/overlay2/layerdb/mounts/ 下创建以容器 ID 命名的目录,内含 mount-id 文件(记录 <mount-id>)。
通过 <mount-id> 可找到 /var/lib/docker/overlay2/<mount-id>/ 目录,包含 merged(挂载点)、diff(即 upperdir,可写层)、work(即 workdir)。
三、UnionFS 在 Docker 镜像与容器中的核心应用
1. 镜像分层构建
Docker 镜像通过 Dockerfile 构建,每一条 Dockerfile 命令(如 FROM、COPY、RUN)都会生成一个只读镜像层,这些层通过 UnionFS 叠加形成完整的镜像文件系统。例如:
dockerfile
FROM python:3.12-slim  # 基础镜像层(只读)
WORKDIR /app           # 生成新的只读层
COPY requirements.txt . # 生成新的只读层
RUN pip install -r requirements.txt  # 生成新的只读层
COPY . .               # 生成新的只读层
优势:不同镜像可共享基础层(如多个 Python 应用共享 python:3.12-slim 基础层),减少磁盘占用;修改镜像时仅需重新构建变更层,提升构建效率。
2. 容器运行时数据管理
容器启动时,Docker 基于镜像的只读层,通过 UnionFS 创建一个可写层(如 Overlay2 的 upperdir):
容器内的文件修改、创建、删除操作,均作用于可写层,底层镜像层保持不变。
容器删除时,仅需删除可写层,镜像层可重复用于其他容器,实现 “一次构建,多次运行”。
四、UnionFS 关键技术总结
特性                  AUFS                                              Overlay2(推荐)
内核依赖           用户态实现,需额外内核补丁       内核原生支持(Linux 4.0+)
分层数量限制    无明确限制,但层越多性能越差    支持最多 128 个只读层
性能                      中等(用户态 IO 转发)    优秀(内核级 IO 处理)
写时复制(CoW)               支持                             支持
删除屏蔽(Whiteout)    基于 .wh.* 文件              基于 .wh.* 文件
Docker 默认支持            早期支持,需手动开启    默认存储驱动(Docker 18.09+)
UnionFS 作为 Docker 存储的底层核心,通过分层叠加和写时复制机制,平衡了镜像的复用性、容器的灵活性和资源的高效性,是 Docker 实现 “轻量级虚拟化” 的关键技术之一。

http://www.dtcms.com/a/407487.html

相关文章:

  • 4.6 BRDF
  • Python GIL全局解释器锁技术演进
  • 小学老师在哪个网站做ppt做羊毛毡的网站
  • 模块化神经网络
  • Python多线程:让程序 “多线作战” 的秘密武器
  • 黟县方坑岭影视基地三剧连拍开机 《生死制暴》影视赋能乡村振兴
  • 微信网站打不开海南搜索引擎优化
  • 国产化(银河麒麟_海光CPU)消息中间件选型及安装
  • 宁波品牌网站推广优化公司章丘营销型网站设计公司
  • p6spy 打印完整sql
  • 【ARM】MDK-Functions界面设置
  • 沈阳市建设局网站首页网站的运行与维护
  • 昌宁县住房和城乡建设网站订阅号做流量 那些电影如何链接网站
  • 【LVS入门宝典】LVS调度算法轮询(RR)深度解析:从原理到实战的公平调度之道
  • udhcpc, udhcpd由 BusyBox编译出来就好
  • 前端 CORS 深度解析
  • HT81696 概述
  • PMP-项目管理-PMBOK第六版_中文版:引论
  • 上海网站建站建设自己做的网站在百度怎么发布
  • SpringBoot+QQ 邮箱邮件开发指南:环境配置、功能实现、异常处理一站式搞定
  • Linux 数据库 Mysql8 主从复制
  • 做网站的图片房产国内免费推广网站
  • 建设网站需要分析什么条件云南软件开发项目管理
  • OpenHands+cpolar:AI编程助手的远程调试新方案
  • 从 0 到 1 掌握 ESP32 RMT(新手友好版)
  • 做设计什么网站可以兼职网站管理与建设总结
  • 少样本学习学习论文分享:多模态性帮助单模态性
  • 深入MySQL底层2-SQL优化与数据库运维管理
  • 设计站网页制作的公司选时代创信
  • 国外服装网站石岩做网站哪家好