中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

AUFS工作原理是什么

發布時間:2021-12-16 10:20:33 來源:億速云 閱讀:138 作者:iii 欄目:云計算

本篇內容主要講解“AUFS工作原理是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“AUFS工作原理是什么”吧!

Rootfs

rootfs(根文件系統)是掛載在容器根目錄上,用來為容器進程提供隔離后執行環境的文件系統,就是所謂的“容器鏡像”。所以,一個最常見的 rootfs,或者說容器鏡像,會包括如下所示的一些目錄和文件,比如 /bin,/etc,/proc 等等:

$ ls /
bin dev etc home lib lib64 mnt opt proc root run sbin sys tmp usr var

而你進入容器之后執行的 /bin/bash,就是 /bin 目錄下的可執行文件,與宿主機的 /bin/bash 完全不同。 對 Docker 項目來說,它最核心的原理實際上就是為待創建的用戶進程:

  • 啟用 Linux Namespace 配置;

  • 設置指定的 Cgroups 參數;

  • 切換進程的根目錄(Change Root)。

另外,需要明確的是,rootfs 只是一個操作系統所包含的文件、配置和目錄,并不包括操作系統內核。在 Linux 操作系統中,這兩部分是分開存放的,操作系統只有在開機啟動時才會加載指定版本的內核鏡像。所以說,rootfs 只包括了操作系統的“軀殼”,并沒有包括操作系統的“靈魂”。

那么,對于容器來說,這個操作系統的“靈魂”又在哪里呢? 實際上,同一臺機器上的所有容器,都共享宿主機操作系統的內核。這就意味著,如果你的應用程序需要配置內核參數、加載額外的內核模塊,以及跟內核進行直接的交互,你就需要注意了:這些操作和依賴的對象,都是宿主機操作系統的內核,它對于該機器上的所有容器來說是一個“全局變量”,牽一發而動全身。這也是容器相比于虛擬機的主要缺陷之一:畢竟后者不僅有模擬出來的硬件機器充當沙盒,而且每個沙盒里還運行著一個完整的 Guest OS 給應用隨便折騰。

聯合文件系統

Docker 在鏡像的設計中,引入了層(layer)的概念。也就是說,用戶制作鏡像的每一步操作,都會生成一個層,也就是一個增量 rootfs。

當然,這個想法不是憑空臆造出來的,而是用到了一種叫作聯合文件系統(Union File System)的能力。

Union File System 也叫 UnionFS,最主要的功能是將多個不同位置的目錄聯合掛載(union mount)到同一個目錄下。比如,我現在有兩個目錄 A 和 B,它們分別有兩個文件:

$ tree
.
├── A
│  ├── a
│  └── x
└── B
  ├── b
  └── x

然后,我使用聯合掛載的方式,將這兩個目錄掛載到一個公共的目錄 C 上:

$ mkdir C
$ mount -t aufs -o dirs=./A:./B none ./C

這時,我再查看目錄 C 的內容,就能看到目錄 A 和 B 下的文件被合并到了一起:

$ tree ./C
./C
├── a
├── b
└── x

可以看到,在這個合并后的目錄 C 里,有 a、b、x 三個文件,并且 x 文件只有一份。這,就是“合并”的含義。此外,如果你在目錄 C 里對 a、b、x 文件做修改,這些修改也會在對應的目錄 A、B 中生效。

Docker 中最常用的聯合文件系統有三種:AUFS、Devicemapper 和 OverlayFS。

AuFS

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

root@cr7-ubuntu:~# grep aufs /proc/filesystems
nodev	aufs

執行以上命令后,如果輸出結果包含aufs,則代表當前操作系統支持 AUFS。AUFS 推薦在 Ubuntu 或 Debian 操作系統下使用,如果你想要在 CentOS 等操作系統下使用 AUFS,需要單獨安裝 AUFS 模塊。

當確認完操作系統支持 AUFS 后,你就可以配置 Docker 的啟動參數了。 先在 /etc/docker 下新建 daemon.json 文件,并寫入以下內容:

{
  "storage-driver": "aufs"
}

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

systemctl daemon-reload && systemctl restart docker

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

root@cr7-ubuntu:~# docker info
Client:
 Debug Mode: false

Server:
 Containers: 1
  Running: 1
  Paused: 0
  Stopped: 0
 Images: 1
 Server Version: 19.03.8
 Storage Driver: aufs  #可以看到 Storage Driver 已經變為 aufs
  Root Dir: /var/lib/docker/aufs
  Backing Filesystem: extfs
  Dirs: 3
  Dirperm1 Supported: true
 Logging Driver: json-file
 Cgroup Driver: cgroupfs
......

可以看到 Storage Driver 已經變為 aufs,證明配置已經生效,配置生效后就可以使用 AUFS 為 Docker 提供聯合文件系統了。

AUFS工作原理

AUFS 是聯合文件系統,意味著它在主機上使用多層目錄存儲,每一個目錄在 AUFS 中都叫作分支,而在 Docker 中則稱之為層(layer),但最終呈現給用戶的則是一個普通單層的文件系統,我們把多層以單一層的方式呈現出來的過程叫作聯合掛載。

AUFS工作原理是什么

如上圖,每一個鏡像層和容器層都是 /var/lib/docker 下的一個子目錄,鏡像層和容器層都在 aufs/diff 目錄下,每一層的目錄名稱是鏡像或容器的 ID 值,聯合掛載點在 aufs/mnt 目錄下,mnt 目錄是真正的容器工作目錄。

下面我們針對 aufs 文件夾下的各目錄結構,在創建容器前后的變化做詳細講述: 1.當一個鏡像未生成容器時,AUFS 的存儲結構如下。

  • diff 文件夾:存儲鏡像內容,每一層都存儲在以鏡像層 ID 命名的子文件夾。

  • layers 文件夾:存儲鏡像層關系的元數據,在 diif 文件夾下的每個鏡像層在這里都會有一個文件,文件的內容為該層鏡像的所有父級鏡像的 ID。

  • mnt 文件夾:聯合掛載點目錄,未生成容器時,該目錄為空。

2.當一個鏡像已經生成容器時,AUFS 存儲結構會發生如下變化。

  • diff 文件夾:當容器運行時,會在 diff 目錄下生成容器層,容器層是可讀寫的,存放容器相對于鏡像層不同的文件(新增或刪除)。另外 diff 目錄中還有 以"-init"結尾的層,夾在容器層和鏡像層之間。Init 層是 Docker 項目單獨生成的一個內部層,專門用來存放 /etc/hosts、/etc/resolv.conf 等信息。

  • layers 文件夾:增加容器層相關的元數據。

  • mnt 文件夾:容器的聯合掛載點,這和容器中看到的文件內容一致。

AUFS工作場景

  1. 讀取文件

  • 文件在容器層中存在時:當文件存在于容器層時,直接從容器層讀取。

  • 當文件在容器層中不存在時:當容器運行時需要讀取某個文件,如果容器層中不存在時,則從鏡像層查找該文件,然后讀取文件內容。

  • 文件既存在于鏡像層,又存在于容器層:當我們讀取的文件既存在于鏡像層,又存在于容器層時,將會從容器層讀取該文件。

  1. 修改文件或目錄 AUFS 對文件的修改采用的是寫時復制的工作機制,這種工作機制可以最大程度節省存儲空間。具體的文件操作機制如下。

  • 第一次修改文件:當我們第一次在容器中修改某個文件時,AUFS 會觸發寫時復制操作,AUFS 首先從鏡像層復制文件到容器層,然后再執行對應的修改操作。

  • AUFS 寫時復制的操作將會復制整個文件,如果文件過大,將會大大降低文件系統的性能,因此當我們有大量文件需要被修改時,AUFS 可能會出現明顯的延遲。好在,寫時復制操作只在第一次修改文件時觸發,對日常使用沒有太大影響。

  • 刪除文件或目錄:當文件或目錄被刪除時,AUFS 并不會真正從鏡像中刪除它,因為鏡像層是只讀的,AUFS 會創建一個特殊的文件或文件夾(在 diff 目錄下創建 .wh 開頭的文件或文件夾),這種特殊的文件或文件夾會阻止容器的訪問。

AUFS演示

Docker的AUFS
拉取鏡像前

拉取鏡像前diff,layers,mnt 目錄都為空

root@cr7-ubuntu:/var/lib/docker/aufs# tree -L 2
.
├── diff
├── layers
└── mnt

3 directories, 0 files
拉取鏡像后

拉取一個apline:latest的基礎鏡像

root@cr7-ubuntu:/var/lib/docker/aufs# docker pull alpine
Using default tag: latest
latest: Pulling from library/alpine
188c0c94c7c5: Pull complete
Digest: sha256:c0e9560cda118f9ec63ddefb4a173a2b2a0347082d7dff7dc14272e7841a5b5a
Status: Downloaded newer image for alpine:latest
docker.io/library/alpine:latest

拉取完鏡像后,可以看到diff,layer,mnt目錄下都新增了一個6b2b93d3f...目錄。其中:

  • diff下的6b2b93d3f...目錄中包含apline鏡像的相關目錄和文件。

  • layers下的6b2b93d3f...文件中內容是空的,因為沒有父級鏡像。

  • mnt下的6b2b93d3f...目錄內容是空的,因為還沒有啟動容器。

root@cr7-ubuntu:/var/lib/docker/aufs# tree -L 3
.
├── diff
│   └── 6b2b93d3feced2838351bad5a459ebc13a55eca45007692ca1622a0c30e986b7
│       ├── bin
│       ├── dev
│       ├── etc
│       ├── home
│       ├── lib
│       ├── media
│       ├── mnt
│       ├── opt
│       ├── proc
│       ├── root
│       ├── run
│       ├── sbin
│       ├── srv
│       ├── sys
│       ├── tmp
│       ├── usr
│       └── var
├── layers
│   └── 6b2b93d3feced2838351bad5a459ebc13a55eca45007692ca1622a0c30e986b7  #文件為空
└── mnt
    └── 6b2b93d3feced2838351bad5a459ebc13a55eca45007692ca1622a0c30e986b7  #目錄為空
創建容器后

使用apline鏡像創建一個容器,但是先不運行該容器。

root@cr7-ubuntu:/var/lib/docker/aufs# docker create -it --name aufs-test alpine
965157ea214e48fdb8f10dbe1b254da442fff223496aacdc7ec2dd29b954b9d9

從下面可以看出,創建一個容器,實際上就是創建了一層讀寫層(容器層),也就是下面的76a069867...目錄。

  • diff目錄中的76a069867...-init目錄用來初始化容器環境,包含初始化的文件。76a069867...目錄是容器運行后才會寫入的層,因為此時容器還沒有運行,所以該目錄是空的。

  • layer目錄中的新增的76a069867...-init文件存放了基本鏡像6b2b93d3f...的ID,76a069867文件存放了父級鏡像76a069867...-init6b2b93d3f...的ID。

  • mnt目錄下也創建了對應的聯合掛載目錄,76a069867...-init76a069867目錄都為空。

root@cr7-ubuntu:/var/lib/docker/aufs# tree -L 3
.
├── diff
│   ├── 6b2b93d3feced2838351bad5a459ebc13a55eca45007692ca1622a0c30e986b7
│   │   ├── bin
│   │   ├── dev
│   │   ├── etc
│   │   ├── home
│   │   ├── lib
│   │   ├── media
│   │   ├── mnt
│   │   ├── opt
│   │   ├── proc
│   │   ├── root
│   │   ├── run
│   │   ├── sbin
│   │   ├── srv
│   │   ├── sys
│   │   ├── tmp
│   │   ├── usr
│   │   └── var
│   ├── 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0
│   └── 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0-init
│       ├── dev
│       └── etc
├── layers
│   ├── 6b2b93d3feced2838351bad5a459ebc13a55eca45007692ca1622a0c30e986b7
│   ├── 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0
│   └── 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0-init
└── mnt
    ├── 6b2b93d3feced2838351bad5a459ebc13a55eca45007692ca1622a0c30e986b7
    ├── 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0
    └── 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0-init

查看layers下ID的關系:

root@cr7-ubuntu:/var/lib/docker/aufs/layers# ll
total 16
drwx------ 2 root root 4096 Nov  9 22:16 ./
drwx------ 5 root root 4096 Nov  9 10:30 ../
-rw-r--r-- 1 root root    0 Nov  9 21:03 6b2b93d3feced2838351bad5a459ebc13a55eca45007692ca1622a0c30e986b7
-rw-r--r-- 1 root root  135 Nov  9 22:16 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0
-rw-r--r-- 1 root root   65 Nov  9 22:16 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0-init

# 6b2b93d3fece..是基本鏡像,就沒有父級鏡像的ID了
root@cr7-ubuntu:/var/lib/docker/aufs/layers# cat 6b2b93d3feced2838351bad5a459ebc13a55eca45007692ca1622a0c30e986b7

# 76a069867...-init文件存放了基本鏡像6b2b93d3f...的ID
root@cr7-ubuntu:/var/lib/docker/aufs/layers# cat 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0-init
6b2b93d3feced2838351bad5a459ebc13a55eca45007692ca1622a0c30e986b7

# 76a069867文件存放了父級鏡像76a069867...-init和6b2b93d3f...的ID
root@cr7-ubuntu:/var/lib/docker/aufs/layers# cat 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0
76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0-init
6b2b93d3feced2838351bad5a459ebc13a55eca45007692ca1622a0c30e986b7
root@cr7-ubuntu:/var/lib/docker/aufs/layers#
啟動容器后

使用 docker start 啟動容器,再次觀察 aufs 下的目錄:

  • diff 目錄的和前面一樣。

  • layer 目錄和前面一樣。

  • mnt 目錄的76a069867目錄新增了 diff 中3個目錄合并的內容

root@cr7-ubuntu:/var/lib/docker/aufs# docker start aufs-test
root@cr7-ubuntu:/var/lib/docker/aufs# tree -L 3
.
├── diff
│   ├── 6b2b93d3feced2838351bad5a459ebc13a55eca45007692ca1622a0c30e986b7
│   │   ├── bin
│   │   ├── dev
│   │   ├── etc
│   │   ├── home
│   │   ├── lib
│   │   ├── media
│   │   ├── mnt
│   │   ├── opt
│   │   ├── proc
│   │   ├── root
│   │   ├── run
│   │   ├── sbin
│   │   ├── srv
│   │   ├── sys
│   │   ├── tmp
│   │   ├── usr
│   │   └── var
│   ├── 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0
│   └── 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0-init
│       ├── dev
│       └── etc
├── layers
│   ├── 6b2b93d3feced2838351bad5a459ebc13a55eca45007692ca1622a0c30e986b7
│   ├── 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0
│   └── 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0-init
└── mnt
    ├── 6b2b93d3feced2838351bad5a459ebc13a55eca45007692ca1622a0c30e986b7
    ├── 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0
    │   ├── bin
    │   ├── dev
    │   ├── etc
    │   ├── home
    │   ├── lib
    │   ├── media
    │   ├── mnt
    │   ├── opt
    │   ├── proc
    │   ├── root
    │   ├── run
    │   ├── sbin
    │   ├── srv
    │   ├── sys
    │   ├── tmp
    │   ├── usr
    │   └── var
    └── 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0-init

45 directories, 3 files

在容器中新建 aufs.txt 文件,可以看到 diff 和mnt中的76a069867目錄都新增了 aufs.txt 文件。

root@cr7-ubuntu:/var/lib/docker/aufs# docker exec aufs-test touch aufs.txt
root@cr7-ubuntu:/var/lib/docker/aufs# docker exec aufs-test ls -lartr
total 64
drwxr-xr-x   12 root     root          4096 Oct 21 09:23 var
drwxrwxrwt    2 root     root          4096 Oct 21 09:23 tmp
drwxr-xr-x    2 root     root          4096 Oct 21 09:23 srv
drwxr-xr-x    2 root     root          4096 Oct 21 09:23 run
drwx------    2 root     root          4096 Oct 21 09:23 root
drwxr-xr-x    2 root     root          4096 Oct 21 09:23 opt
drwxr-xr-x    2 root     root          4096 Oct 21 09:23 mnt
drwxr-xr-x    5 root     root          4096 Oct 21 09:23 media
drwxr-xr-x    2 root     root          4096 Oct 21 09:23 home
drwxr-xr-x    7 root     root          4096 Oct 21 09:23 usr
drwxr-xr-x    2 root     root          4096 Oct 21 09:23 sbin
drwxr-xr-x    7 root     root          4096 Oct 21 09:23 lib
drwxr-xr-x    2 root     root          4096 Oct 21 09:23 bin
drwxr-xr-x   15 root     root          4096 Nov 10 03:16 etc
-rwxr-xr-x    1 root     root             0 Nov 10 03:16 .dockerenv
dr-xr-xr-x   13 root     root             0 Nov 10 03:17 sys
dr-xr-xr-x  255 root     root             0 Nov 10 03:17 proc
drwxr-xr-x    5 root     root           360 Nov 10 03:17 dev
-rw-r--r--    1 root     root             0 Nov 10 03:19 aufs.txt
drwxr-xr-x   25 root     root          4096 Nov 10 03:19 ..
drwxr-xr-x   25 root     root          4096 Nov 10 03:19 .

root@cr7-ubuntu:/var/lib/docker/aufs# tree -L 3
.
├── diff
│   ├── 6b2b93d3feced2838351bad5a459ebc13a55eca45007692ca1622a0c30e986b7
│   │   ├── bin
│   │   ├── dev
│   │   ├── etc
│   │   ├── home
│   │   ├── lib
│   │   ├── media
│   │   ├── mnt
│   │   ├── opt
│   │   ├── proc
│   │   ├── root
│   │   ├── run
│   │   ├── sbin
│   │   ├── srv
│   │   ├── sys
│   │   ├── tmp
│   │   ├── usr
│   │   └── var
│   ├── 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0
│   │   └── aufs.txt  
│   └── 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0-init
│       ├── dev
│       └── etc
├── layers
│   ├── 6b2b93d3feced2838351bad5a459ebc13a55eca45007692ca1622a0c30e986b7
│   ├── 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0
│   └── 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0-init
└── mnt
    ├── 6b2b93d3feced2838351bad5a459ebc13a55eca45007692ca1622a0c30e986b7
    ├── 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0
    │   ├── aufs.txt
    │   ├── bin
    │   ├── dev
    │   ├── etc
    │   ├── home
    │   ├── lib
    │   ├── media
    │   ├── mnt
    │   ├── opt
    │   ├── proc
    │   ├── root
    │   ├── run
    │   ├── sbin
    │   ├── srv
    │   ├── sys
    │   ├── tmp
    │   ├── usr
    │   └── var
    └── 76a069867e2f7a662dda1c9e8ec0e3df868319a51631a584824a2c70e1ca01c0-init

45 directories, 5 files

可是,你有沒有想到這樣一個問題:如果我現在要做的,是刪除只讀層里的一個文件呢?

為了實現這樣的刪除操作,AuFS 會在可讀寫層創建一個 whiteout 文件,把只讀層里的文件“遮擋”起來。比如,你要刪除只讀層里一個名叫 foo 的文件,那么這個刪除操作實際上是在可讀寫層創建了一個名叫.wh.foo 的文件。這樣,當這兩個層被聯合掛載之后,foo 文件就會被.wh.foo 文件“遮擋”起來,“消失”了。這個功能,就是“ro+wh”的掛載方式,即只讀 +whiteout 的含義。我喜歡把 whiteout 形象地翻譯為:“白障”。

AUFS手動演示
準備演示目錄和文件
root@cr7-ubuntu:/tmp/aufs# tree
.
├── diff  
│   ├── container #容器層目錄
│   │   └── container.txt
│   ├── image1   #鏡像層目錄
│   │   └── image1.txt
│   └── image2   #鏡像層目錄
│       └── image2.txt
└── mnt

5 directories, 3 files
創建 AUFS 聯合文件系統

使用 mount 命令可以創建 AUFS 類型的文件系統,命令如下:

root@cr7-ubuntu:/tmp/aufs# mount -t aufs -o dirs=./diff/container/:./diff/image1/:./diff/image2/ none ./mnt/

mount 命令創建 AUFS 類型文件系統時,這里要注意,dirs 參數第一個冒號默認為讀寫權限,后面的目錄均為只讀權限,與 Docker 容器使用 AUFS 的模式一致。

執行完上述命令后,mnt 變成了 AUFS 的聯合掛載目錄,我們可以使用 mount 命令查看一下已經創建的 AUFS 文件系統:

root@cr7-ubuntu:/tmp/aufs# mount -t aufs
none on /tmp/aufs/mnt type aufs (rw,relatime,si=1448e4c4c7bc84)

我們每創建一個 AUFS 文件系統,AUFS 都會為我們生成一個 ID,這個 ID 在 /sys/fs/aufs/ 會創建對應的目錄,在這個 ID 的目錄下可以查看文件掛載的權限。

root@cr7-ubuntu:/tmp/aufs# cat /sys/fs/aufs/si_1448e4c4c7bc84/*
/tmp/aufs/diff/container=rw
/tmp/aufs/diff/image1=ro
/tmp/aufs/diff/image2=ro
64
65
66
/tmp/aufs/diff/container/.aufs.xino

可以看到container目錄的權限為rw(代表可讀寫),image1和image2的權限為ro(代表只讀)。 為了驗證 mnt 目錄下可以看到 container、image1 和 image2 目錄下的所有內容,我們使用 ls 命令查看一下 mnt 目錄:

root@cr7-ubuntu:/tmp/aufs# ls mnt/
container.txt  image1.txt  image2.txt

此時的目錄結構:

root@cr7-ubuntu:/tmp/aufs# tree
.
├── diff
│   ├── container
│   │   └── container.txt
│   ├── image1
│   │   └── image1.txt
│   └── image2
│       └── image2.txt
└── mnt  #mnt目錄下包含鏡像層和容器層的內容
    ├── container.txt
    ├── image1.txt
    └── image2.txt

5 directories, 6 files

可以看到 mnt 目錄下已經出現了我們準備的所有鏡像層和容器層的文件。下面讓我們來驗證一下 AUFS 的寫時復制。

驗證 AUFS 的寫時復制

AUFS 的寫時復制是指在容器中,只有需要修改某個文件時,才會把文件從鏡像層復制到容器層,下面我們通過修改聯合掛載目錄 mnt 下的內容來驗證下這個過程。

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

root@cr7-ubuntu:/tmp/aufs# echo "Hello, Image layer1 changed!" > mnt/image1.txt

然后我們查看下 image1/image1.txt 文件內容:

root@cr7-ubuntu:/tmp/aufs# cat diff/image1/image1.txt
Hello,Image layer1!

發現“鏡像層”的 image1.txt 文件并未被修改。 然后我們查看一下"容器層"對應的 image1.txt 文件內容:

root@cr7-ubuntu:/tmp/aufs# cat diff/container/image1.txt
Hello, Image layer1 changed!

發現 AUFS 在“容器層”自動創建了 image1.txt 文件,并且內容為我們剛才寫入的內容。此時的目錄結構:

root@cr7-ubuntu:/tmp/aufs# tree
.
├── diff
│   ├── container
│   │   ├── container.txt
│   │   └── image1.txt #自動創建的image1.txt文件
│   ├── image1
│   │   └── image1.txt
│   └── image2
│       └── image2.txt
└── mnt
    ├── container.txt
    ├── image1.txt
    └── image2.txt

5 directories, 7 files

到此,相信大家對“AUFS工作原理是什么”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

兴和县| 济南市| 若尔盖县| 罗甸县| 庄浪县| 长葛市| 驻马店市| 永清县| 子长县| 玉山县| 杭锦后旗| 临武县| 错那县| 马边| 额济纳旗| 平潭县| 乳山市| 电白县| 巴里| 嘉峪关市| 明水县| 长汀县| 新建县| 泗洪县| 屏南县| 上饶县| 松原市| 静乐县| 伊宁市| 同仁县| 华容县| 临海市| 健康| 年辖:市辖区| 山西省| 水富县| 浦城县| 浦北县| 西贡区| 嘉定区| 从化市|