我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Docker核心组件之联合文件系统怎么配置

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Docker核心组件之联合文件系统怎么配置

今天小编给大家分享一下Docker核心组件之联合文件系统怎么配置的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

1. 联合文件系统的定义

联合文件系统(Union File System,Unionfs)是一种分层的轻量级文件系统,它可以把多个目录内容联合挂载到同一目录下,从而形成一个单一的文件系统,这种特性可以让使用者像是使用一个目录一样使用联合文件系统。

那联合文件系统对于 Docker 是一个怎样的存在呢?它可以说是 Docker 镜像和容器的基础,因为它可以使 Docker 可以把镜像做成分层的结构,从而使得镜像的每一层可以被共享。例如两个业务镜像都是基于 CentOS 7 镜像构建的,那么这两个业务镜像在物理机上只需要存储一次 CentOS 7 这个基础镜像即可,从而节省大量存储空间。

Docker 中最常用的联合文件系统有三种:AUFS、Devicemapper 和 OverlayFS。

本文主要讲解 Docker 中最常用的联合文件系统里的 AUFS,为什么呢?因为 AUFS 是 Docker 最早使用的文件系统驱动,多用于 Ubuntu 和 Debian 系统中。在 Docker 早期,OverlayFS 和 Devicemapper 相对不够成熟,AUFS 是最早也是最稳定的文件系统驱动。

2. 配置 Docker 的 AUFS 模式

AUFS 目前并未被合并到 Linux 内核主线,因此只有 Ubuntu 和 Debian 等少数操作系统支持 AUFS。你可以使用以下命令查看你的系统是否支持 AUFS:

$ grep aufs /proc/filesystemsnodev   aufs

执行以上命令后,如果输出结果包含aufs,则代表当前操作系统支持 AUFS。AUFS 推荐在 Ubuntu 或 Debian 操作系统下使用,如果你想要在 CentOS 等操作系统下使用 AUFS,需要单独安装 AUFS 模块(生产环境不推荐在 CentOS 下使用 AUFS),安装完成后使用上述命令输出结果中有aufs即可。
当确认完操作系统支持 AUFS 后,你就可以配置 Docker 的启动参数了。

先在 /etc/docker 下新建 daemon.json 文件,并写入以下内容:

{  "storage-driver": "aufs"}

然后使用以下命令重启 Docker:

$ sudo systemctl restart docker

Docker 重启以后使用docker info命令即可查看配置是否生效:

$ sudo docker infoClient: Debug Mode: falseServer: Containers: 0  Running: 0  Paused: 0  Stopped: 0 Images: 1 Server Version: 19.03.12 Storage Driver: aufs  Root Dir: /var/lib/docker/aufs  Backing Filesystem: extfs  Dirs: 1  Dirperm1 Supported: true

可以看到 Storage Driver 已经变为 aufs,证明配置已经生效,配置生效后就可以使用 AUFS 为 Docker 提供联合文件系统了。

3. AUFS 工作原理

3.1 AUFS 如何存储文件

AUFS 是联合文件系统,意味着它在主机上使用多层目录存储,每一个目录在 AUFS 中都叫作分支,而在 Docker 中则称之为层(layer),但最终呈现给用户的则是一个普通单层的文件系统,我们把多层以单一层的方式呈现出来的过程叫作联合挂载。

Docker核心组件之联合文件系统怎么配置

如图 1 所示,每一个镜像层和容器层都是 /var/lib/docker 下的一个子目录,镜像层和容器层都在 aufs/diff 目录下,每一层的目录名称是镜像或容器的 ID 值,联合挂载点在 aufs/mnt 目录下,mnt 目录是真正的容器工作目录。

下面我们针对 aufs 文件夹下的各目录结构,在创建容器前后的变化做详细讲述。

当一个镜像未生成容器时,AUFS 的存储结构如下。

  • diff 文件夹:存储镜像内容,每一层都存储在以镜像层 ID 命名的子文件夹中。

  • layers 文件夹:存储镜像层关系的元数据,在 diif 文件夹下的每个镜像层在这里都会有一个文件,文件的内容为该层镜像的父级镜像的 ID。

  • mnt 文件夹:联合挂载点目录,未生成容器时,该目录为空。

当一个镜像已经生成容器时,AUFS 存储结构会发生如下变化。

  • diff 文件夹:当容器运行时,会在 diff 目录下生成容器层。

  • layers 文件夹:增加容器层相关的元数据。

  • mnt 文件夹:容器的联合挂载点,这和容器中看到的文件内容一致。

3.2 AUFS 如何工作

读取文件

当我们在容器中读取文件时,可能会有以下场景。

  • 文件在容器层中存在时:当文件存在于容器层时,直接从容器层读取。

  • 当文件在容器层中不存在时:当容器运行时需要读取某个文件,如果容器层中不存在时,则从镜像层查找该文件,然后读取文件内容。

  • 文件既存在于镜像层,又存在于容器层:当我们读取的文件既存在于镜像层,又存在于容器层时,将会从容器层读取该文件。

修改文件或目录

AUFS 对文件的修改采用的是写时复制的工作机制,这种工作机制可以最大程度节省存储空间。

具体的文件操作机制如下。

  • 第一次修改文件:

当我们第一次在容器中修改某个文件时,AUFS 会触发写时复制操作,AUFS 首先从镜像层复制文件到容器层,然后再执行对应的修改操作。

AUFS 写时复制的操作将会复制整个文件,如果文件过大,将会大大降低文件系统的性能,因此当我们有大量文件需要被修改时,AUFS 可能会出现明显的延迟。好在,写时复制操作只在第一次修改文件时触发,对日常使用没有太大影响。

  • 删除文件或目录:

当文件或目录被删除时,AUFS 并不会真正从镜像中删除它,因为镜像层是只读的,AUFS 会创建一个特殊的文件或文件夹,这种特殊的文件或文件夹会阻止容器的访问。

4. AUFS 演示

4.1 准备演示目录和文件

首先我们在 /tmp 目录下创建 aufs 目录:

$ cd /tmp/tmp$ mkdir aufs

准备挂载点目录:

/tmp$ cd aufs/tmp/aufs$ mkdir mnt

接下来准备容器层内容:

## 创建镜像层目录/tmp/aufs$ mkdir container1## 在镜像层目录下准备一个文件/tmp/aufs$ echo Hello, Container layer! > container1/container1.txt

最后准备镜像层内容:

## 创建两个镜像层目录/tmp/aufs$ mkdir image1 && mkdir image2## 分别写入数据/tmp/aufs$ echo Hello, Image layer1! > image1/image1.txt/tmp/aufs$ echo Hello, Image layer2! > image2/image2.txt

准备好的目录和文件结构如下:

/tmp/aufs$ tree ..|-- container1|   `-- container1.txt|-- image1|   `-- image1.txt|-- image2|   `-- image2.txt`-- mnt4 directories, 3 files

4.2 创建 AUFS 联合文件系统

使用 mount 命令可以创建 AUFS 类型的文件系统,命令如下:

/tmp/aufs$ sudo mount -t aufs -o dirs=./container1:./image2:./image1  none ./mnt

mount 命令创建 AUFS 类型文件系统时,这里要注意,dirs 参数第一个冒号默认为读写权限,后面的目录均为只读权限,与 Docker 容器使用 AUFS 的模式一致。

执行完上述命令后,mnt 变成了 AUFS 的联合挂载目录,我们可以使用 mount 命令查看一下已经创建的 AUFS 文件系统:

/tmp/aufs$ mount -t aufsnone on /tmp/aufs/mnt type aufs (rw,relatime,si=4174b83d649ffb7c)

我们每创建一个 AUFS 文件系统,AUFS 都会为我们生成一个 ID,这个 ID 在 /sys/fs/aufs/ 会创建对应的目录,在这个 ID 的目录下可以查看文件挂载的权限。

tmp/aufs$ cat /sys/fs/aufs/si_4174b83d649ffb7c/*/tmp/aufs/container1=rw/tmp/aufs/image2=ro/tmp/aufs/image1=ro646566

可以看到 container1 目录的权限为 rw(代表可读写),image1 和 image2 的权限为 ro(代表只读)。

为了验证 mnt 目录下可以看到 container1、image1 和 image2 目录下的所有内容,我们使用 ls 命令查看一下 mnt 目录:

/tmp/aufs$ ls -l mnt/total 12-rw-rw-r-- 1 ubuntu ubuntu 24 Sep  9 16:55 container1.txt-rw-rw-r-- 1 ubuntu ubuntu 21 Sep  9 16:59 image1.txt-rw-rw-r-- 1 ubuntu ubuntu 21 Sep  9 16:59 image2.txt

可以看到 mnt 目录下已经出现了我们准备的所有镜像层和容器层的文件。下面让我们来验证一下 AUFS 的写时复制。

4.3 验证 AUFS 的写时复制

AUFS 的写时复制是指在容器中,只有需要修改某个文件时,才会把文件从镜像层复制到容器层,下面我们通过修改联合挂载目录 mnt 下的内容来验证下这个过程。

我们使用以下命令修改 mnt 目录下的 image1.txt 文件:

/tmp/aufs$ echo Hello, Image layer1 changed! > mnt/image1.txt

然后我们查看下 image1/image1.txt 文件内容:

/tmp/aufs$ cat image1/image1.txtHello, Image layer1!

发现“镜像层”的 image1.txt 文件并未被修改。
然后我们查看一下"容器层"对应的 image1.txt 文件内容:

/tmp/aufs$ ls -l container1/total 8-rw-rw-r-- 1 ubuntu ubuntu 24 Sep  9 16:55 container1.txt-rw-rw-r-- 1 ubuntu ubuntu 29 Sep  9 17:21 image1.txt## 查看文件内容/tmp/aufs$ cat container1/image1.txtHello, Image layer1 changed!

发现 AUFS 在“容器层”自动创建了 image1.txt 文件,并且内容为我们刚才写入的内容。

以上就是“Docker核心组件之联合文件系统怎么配置”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Docker核心组件之联合文件系统怎么配置

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Docker核心组件之联合文件系统怎么配置

今天小编给大家分享一下Docker核心组件之联合文件系统怎么配置的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1. 联合文件
2023-06-30

hadoop核心配置文件怎么查看

要查看 Hadoop 的核心配置文件,您可以使用以下命令来查找 Hadoop 安装目录中的配置文件:ls /path/to/hadoop/etc/hadoop通常,Hadoop 的核心配置文件位于 Hadoop 安装目录的 etc/had
hadoop核心配置文件怎么查看
2024-03-06

linux系统下hosts文件怎么配置

这篇文章主要为大家展示了“linux系统下hosts文件怎么配置”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“linux系统下hosts文件怎么配置”这篇文章吧。 hosts文件  hosts
2023-06-09

win10系统镜像文件怎么配置

这篇文章主要介绍了win10系统镜像文件怎么配置的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇win10系统镜像文件怎么配置文章都会有所收获,下面我们一起来看看吧。1、制作好u盘启动盘并插入电脑,按笔记本一键u
2023-07-01

如何配置CentOS系统以限制用户对系统核心文件的访问权限

要限制用户对系统核心文件的访问权限,你可以通过以下步骤来配置CentOS系统:1. 使用root用户登录到CentOS系统。2. 打开/etc/sysctl.conf文件,可以使用vi或nano等文本编辑器来编辑该文件:```sudo vi
2023-10-09

SpringBoot怎么配置Actuator组件实现系统监控

这篇文章主要介绍“SpringBoot怎么配置Actuator组件实现系统监控”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“SpringBoot怎么配置Actuator组件实现系统监控”文章能帮助大
2023-06-08

CentOS vsftp怎么安装系统帐户与配置文件

本篇内容介绍了“CentOS vsftp怎么安装系统帐户与配置文件”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一.安装:1.安装CentO
2023-06-16

win10系统垃圾文件自动清理怎么配置

要配置Win10系统自动清理垃圾文件,可以按照以下步骤进行操作:1. 打开“设置”:在任务栏上点击“开始”按钮,然后点击“设置”图标(齿轮形状)。2. 进入“系统”设置:在“设置”窗口中,点击“系统”选项。3. 选择“存储”:在“系统”设置
2023-09-05

win101909系统怎么彻底更改用户名配置文件

这篇文章主要讲解了“win101909系统怎么彻底更改用户名配置文件”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“win101909系统怎么彻底更改用户名配置文件”吧!1.打开【文件资源管理
2023-07-01

linux系统之间怎么通过nfs网络文件系统设置挂载

这篇文章主要介绍“linux系统之间怎么通过nfs网络文件系统设置挂载”,在日常操作中,相信很多人在linux系统之间怎么通过nfs网络文件系统设置挂载问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”linux
2023-06-05

云服务器怎么搭建python环境配置系统文件

以下是一个简单的Python搭建服务器的示例代码,使用OpenStackAPI和Koa库进行搭建:```pythonimportmysqlimportosimporttkinterimportosutils.server.SimpleServers.Servers.PriorityQueue安装Koa库definstallos():systempath="yourinstalla
2023-10-26

怎么在CentOS系统中使用配置文件修改IP地址

怎么在CentOS系统中使用配置文件修改IP地址?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。适用范围及演示系统适用范围:linux演示系统:centos6.4centos
2023-06-10

云服务器怎么搭建python环境配置系统文件夹

以下是一个基本的Python服务器搭建示例,包括以下文件夹和目录:服务器名称(例如my_server):创建服务器后,用户只需将其命名为该名称即可。根目录:包含所有文件的目录,包括web.py,python.py,scrapy.config,python.utils,pyshops,pyshop,pymovies,pymovie,pyfile,pyfileshards,pyfiles,py
2023-10-26

怎么解决docker容器重启之后/etc下某些配置文件被重置的问题

这篇文章给大家分享的是有关怎么解决docker容器重启之后/etc下某些配置文件被重置的问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1./etc/hosts, /etc/resolv.conf和/etc/h
2023-06-14

Linux系统中管理用户和用户组的相关配置文件是什么

本篇内容介绍了“Linux系统中管理用户和用户组的相关配置文件是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Linux 是一个多用户、
2023-06-12

云服务器怎么搭建python环境配置系统文件权限

要搭建一个云服务器系统,您需要考虑以下几个步骤:准备服务器环境和操作系统:您需要一个Python环境(例如Python安装目录和Pythonwebapps目录下的文件夹),并且为Python操作系统准备相应的文件夹。创建云服务器配置文件:在云服务器系统中,您通常会创建一个文件夹,用于放置服务器的相关配置文件(例如:服务器名称、端口号、IP地址等)。配置文件权限:在Python中,您需要配
2023-10-26

Linux系统中如果Centos没有网卡eth0配置文件怎么办

这篇文章主要介绍Linux系统中如果Centos没有网卡eth0配置文件怎么办,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!临时解决办法1、大家都知道linux下面设置ip是 ifconfig 命令通过下面命令即可临
2023-06-12

云服务器怎么搭建python环境配置系统网络文件

要搭建Python环境,你需要一个Python虚拟机(VM)或者虚拟环境(VL)来安装、配置和管理系统和网络文件。下面是使用Dockerfile和Python虚拟机搭建云服务器的步骤:在Docker镜像中安装Dockerfile.sh文件。这将包含你在虚拟机或者云服务提供商的安装路径。在VM镜像中安装Python虚拟机(VM)。VM是运行云服务器的Python虚拟机。你需要将该VM镜像安
2023-10-26

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录