当前位置: 首页 > 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+)
Docker 完成 “轻量级虚拟化” 的关键技术之一。就是UnionFS 作为 Docker 存储的底层核心,通过分层叠加和写时复制机制,平衡了镜像的复用性、容器的灵活性和资源的高效性,

http://www.jsqmd.com/news/11146/

相关文章:

  • 深入解析:如何解决 pip install 安装报错 ModuleNotFoundError: No module named ‘tokenizers’ 问题
  • P13274 [NOI2025] 三目运算符
  • Microsoft Office不小心卸载或重装系统后,如何重新安装 ... - sherlock
  • HTTPS 抓包乱码怎么办?原因剖析、排查步骤与实战工具对策(HTTPS 抓包乱码、gzipbrotli、TLS 解密、iOS 抓包) - 实践
  • 使用JaCoCo进行代码覆盖率分析
  • 计算机视觉专家入选德国国家科学院
  • 2025 年工程管理软件/软件系统/软件App/软件平台/工程管理软件和验房系统公司/企业推荐榜:数字化转型下的实用选型指南
  • solutions
  • 技术面:Spring (事务传播机制、事务失效的原因、BeanFactory和FactoryBean的关系)
  • B2002 Hello,World!【入门】
  • 完整教程:跨境必看:TikTok Ads广告竞价策略分享
  • 安装与配置MySQL 8 on Ubuntu,包括权限授予、数据库备份及远程连接
  • 04-最简单的字符设备驱动
  • 完整教程:手机可视化方案(针对浓度识别)
  • AI元人文系列文章:决策范式与无为而治
  • 用批处理材料实现Excel和word文件的重造
  • SAP导入证书
  • 洛谷《深入浅出程序设计竞赛(基础篇)》题解
  • 实用指南:Linux编译SRS并测试RTMP流
  • 华为链路聚合配置
  • iOS 26 软件性能测试全流程,启动渲染资源压力对比与优化策略 - 详解
  • 离线安装 mysql
  • 2025 年公共/商场/学校/地铁/电影院/会所/机场/卫生间隔断厂家选购指南:优质厂商推荐与实用选择策略
  • 为什么不该用 Double 表示金额及解决方案
  • 实用指南:WXML 编译错误修复总结
  • Windows开发环境安装备忘录
  • Vue.use(Vuex)
  • [Gym-100343E]Convex Permutominoes 题解
  • MyBatis 中的动态 SQL 的相关使用方法(Javaee/MyBatis) - 教程
  • 网络优化问题