首頁 運維 Docker 什麼是docker最早支援的儲存引擎

什麼是docker最早支援的儲存引擎

May 12, 2022 pm 03:27 PM
docker

AUFS是docker最早支援的儲存引擎。 AUFS是一種Union File System,是檔案層級的儲存驅動,是Docker早期用的儲存驅動,是Docker18.06版本之前,Ubuntu14.04版本前推薦的,支援xfs、ext4檔案。

什麼是docker最早支援的儲存引擎

本教學操作環境:linux7.3系統、docker20版、Dell G3電腦。

AUFS是docker最早支援的儲存引擎。

Docker 的儲存引擎

#Docker 的儲存引擎設計想法是這樣,但是針對不同的檔案系統,是由不同的儲存驅動去實現的。下面我們就來聊聊 Docker 的儲存驅動程式。

Docker 主要有一下幾類儲存驅動:

  • overlay2:是目前版本推薦的儲存驅動,無需額外的依賴和配置即可發揮絕佳的效能。在 18.09 版本之後替換了 overlay 儲存驅動程式。支援 xfs,ext4 檔案系統。

  • aufs:Docker 最早使用的儲存驅動程式,是 Docker 18.06 版本之前,Ubuntu 14.04 版本前推薦的。支援 xfs,ext4 檔案系統。

  • devicemapper:是較早版本的 CentOS 和 RHEL 系統建議的儲存驅動,因為它們不支援 overlay2,需要 direct-lvm 的支援。

  • btrfs:僅用於 btrfs 檔案系統。

  • zfs:僅用於 zfs 檔案系統。

  • vfs:不依賴檔案系統,但是效能奇差,主要用來測試。

需要注意的是,overlay2,overlay,aufs 的層是基於文件的,當單文件的寫並發較高時需要大內存的支持,且讀寫層可能因為單一文件而變得很大。 devicemapper,btrfs,zfs 的層是基於區塊儲存的,因此對於單一檔案的高並發影響不大。但是 btrfs 和 zfs 非常消耗記憶體。

docker AUFS

AUFS是一種Union File System,所謂UnionFS就是把不同物理位置的目錄合併mount到同一個目錄中。 UnionFS的一個最主要的應用是,把一張CD/DVD和一個硬碟目錄給聯合mount在一起,然後,你就可以對這個只讀的CD/DVD上的檔案進行修改(當然,修改的檔案存於硬碟上的目錄裡)。

AUFS又叫Another UnionFS,後來叫Alternative UnionFS,後來可能覺得不夠霸氣,叫成Advance UnionFS。是由Junjiro Okajima(岡島順治郎)在2006年開發的,AUFS完全重寫了早期的UnionFS 1.x,主要目的是為了可靠性和性能,並且引入了一些新的功能,例如可寫分支的負載平衡。 AUFS在使用上全相容UnionFS,而且比之前的UnionFS在穩定性和效能上都好很多,後來的UnionFS 2.x開始抄AUFS中的功能。但他居然沒有進到Linux主幹裡,就是因為Linus不讓,基本上是因為程式碼量比較多,而且寫得爛(相對於只有3000行的union mount和10000行的UnionFS,以及其它平均下來只有6000行程式碼左右的VFS,AUFS居然有30000行程式碼),所以,岡島不斷地改進程式碼質量,不斷地提交,不斷地被Linus拒掉,所以,到今天AUFS都還進不了Linux主幹(今天你可以看到AUFS的程式碼其實還好了,比起OpenSSL好N倍,要嘛就是Linus對程式碼的品質要求非常高,要嘛就是Linus就是不喜歡AUFS)。

不過,好在有很多發行版都用了AUFS,例如:Ubuntu 10.04,Debian6.0, Gentoo Live CD支援AUFS,所以,也OK了。

好了,扯完這些閒話,我們還是看一個示例吧(環境:Ubuntu 14.04)

#首先,我們建上兩個目錄(水果和蔬菜),並在這兩個目錄中放上一些文件,水果中有蘋果和番茄,蔬菜有胡蘿蔔和番茄。

$ tree
.
├── fruits
│   ├── apple
│   └── tomato
└── vegetables
    ├── carrots
    └── tomato
登入後複製

然後,我們輸入以下命令:

# 创建一个mount目录
$ mkdir mnt

# 把水果目录和蔬菜目录union mount到 ./mnt目录中
$ sudo mount -t aufs -o dirs=./fruits:./vegetables none ./mnt

#  查看./mnt目录
$ tree ./mnt
./mnt
├── apple
├── carrots
└── tomato
登入後複製

我們可以看到在./mnt目錄下有三個文件,蘋果apple、胡蘿蔔carrots和番茄tomato。水果和蔬菜的目錄被union到了./mnt目錄下了。

我們來修改一下其中的文件內容:

$ echo mnt > ./mnt/apple
$ cat ./mnt/apple
mnt
$ cat ./fruits/apple
mnt
登入後複製

上面的範例,我們可以看到./mnt/apple的內容改了,./fruits/apple的內容也改了。

$ echo mnt_carrots > ./mnt/carrots
$ cat ./vegetables/carrots 

$ cat ./fruits/carrots
mnt_carrots
登入後複製

上面的範例,我們可以看到,我們修改了./mnt/carrots的文件內容,./vegetables/carrots並沒有變化,反而是./fruits/carrots的目錄中出現了carrots文件,其內容是我們在./mnt/carrots裡的內容。

也就是說,我們在mount aufs指令中,我們沒有指它vegetables和fruits的目錄權限,預設上來說,指令列上第一個(最左邊)的目錄是可讀可寫的,後面的都是唯讀的。 (一般來說,最前面的目錄應該是可寫的,而後面的都應該是唯讀的)

所以,如果我們像下面這樣指定權限來mount aufs,你就會發現有不一樣的效果(記得先把上面./fruits/carrots的檔案刪除了):

$ sudo mount -t aufs -o dirs=./fruits=rw:./vegetables=rw none ./mnt

$ echo "mnt_carrots" > ./mnt/carrots 

$ cat ./vegetables/carrots
mnt_carrots

$ cat ./fruits/carrots
cat: ./fruits/carrots: No such file or directory
登入後複製

现在,在这情况下,如果我们要修改./mnt/tomato这个文件,那么究竟是哪个文件会被改写?

$ echo "mnt_tomato" > ./mnt/tomato 

$ cat ./fruits/tomato
mnt_tomato

$ cat ./vegetables/tomato
I am a vegetable
登入後複製

可见,如果有重复的文件名,在mount命令行上,越往前的就优先级越高。

你可以用这个例子做一些各种各样的试验,我这里主要是给大家一个感性认识,就不展开试验下去了。

那么,这种UnionFS有什么用?

历史上,有一个叫Knoppix的Linux发行版,其主要用于Linux演示、光盘教学、系统急救,以及商业产品的演示,不需要硬盘安装,直接把CD/DVD上的image运行在一个可写的存储设备上(比如一个U盘上),其实,也就是把CD/DVD这个文件系统和USB这个可写的系统给联合mount起来,这样你对CD/DVD上的image做的任何改动都会在被应用在U盘上,于是乎,你可以对CD/DVD上的内容进行任意的修改,因为改动都在U盘上,所以你改不坏原来的东西。

我们可以再发挥一下想像力,你也可以把一个目录,比如你的源代码,作为一个只读的template,和另一个你的working directory给union在一起,然后你就可以做各种修改而不用害怕会把源代码改坏了。有点像一个ad hoc snapshot。

Docker把UnionFS的想像力发挥到了容器的镜像。你是否还记得我在介绍Linux Namespace上篇中用mount namespace和chroot山寨了一镜像。现在当你看过了这个UnionFS的技术后,你是不是就明白了,你完全可以用UnionFS这样的技术做出分层的镜像来。

下图来自Docker的官方文档Layer,其很好的展示了Docker用UnionFS搭建的分层镜像。

什麼是docker最早支援的儲存引擎

关于docker的分层镜像,除了aufs,docker还支持btrfs, devicemapper和vfs,你可以使用 -s 或 storage-driver= 选项来指定相关的镜像存储。在Ubuntu 14.04下,docker默认Ubuntu的 aufs(在CentOS7下,用的是devicemapper,关于devicemapper,我会以以后的文章中讲解)你可以在下面的目录中查看相关的每个层的镜像:

/var/lib/docker/aufs/diff/<id>
登入後複製

AUFS的一些特性

AUFS有所有Union FS的特性,把多个目录,合并成同一个目录,并可以为每个需要合并的目录指定相应的权限,实时的添加、删除、修改已经被mount好的目录。而且,他还能在多个可写的branch/dir间进行负载均衡。

上面的例子,我们已经看到AUFS的mount的示例了。下面我们来看一看被union的目录(分支)的相关权限:

  • rw表示可写可读read-write。

  • ro表示read-only,如果你不指权限,那么除了第一个外ro是默认值,对于ro分支,其永远不会收到写操作,也不会收到查找whiteout的操作。

  • rr表示real-read-only,与read-only不同的是,rr标记的是天生就是只读的分支,这样,AUFS可以提高性能,比如不再设置inotify来检查文件变动通知。

推荐学习:《docker视频教程

以上是什麼是docker最早支援的儲存引擎的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

docker怎麼退出容器 docker怎麼退出容器 Apr 15, 2025 pm 12:15 PM

退出 Docker 容器的四種方法:容器終端中使用 Ctrl D 快捷鍵容器終端中輸入 exit 命令宿主機終端中使用 docker stop &lt;container_name&gt; 命令宿主機終端中使用 docker kill &lt;container_name&gt; 命令(強制退出)

docker容器名稱怎麼查 docker容器名稱怎麼查 Apr 15, 2025 pm 12:21 PM

可以通過以下步驟查詢 Docker 容器名稱:列出所有容器(docker ps)。篩選容器列表(使用 grep 命令)。獲取容器名稱(位於 "NAMES" 列中)。

docker內的文件怎麼拷貝到外面 docker內的文件怎麼拷貝到外面 Apr 15, 2025 pm 12:12 PM

Docker 中將文件拷貝到外部主機的方法:使用 docker cp 命令:執行 docker cp [選項] &lt;容器路徑&gt; &lt;主機路徑&gt;。使用數據卷:在主機上創建目錄,在創建容器時使用 -v 參數掛載該目錄到容器內,實現文件雙向同步。

docker怎麼重啟 docker怎麼重啟 Apr 15, 2025 pm 12:06 PM

重啟 Docker 容器的方法:獲取容器 ID(docker ps);停止容器(docker stop &lt;container_id&gt;);啟動容器(docker start &lt;container_id&gt;);驗證重啟成功(docker ps)。其他方法:Docker Compose(docker-compose restart)或 Docker API(參考 Docker 文檔)。

docker怎麼啟動mysql docker怎麼啟動mysql Apr 15, 2025 pm 12:09 PM

在 Docker 中啟動 MySQL 的過程包含以下步驟:拉取 MySQL 鏡像創建並啟動容器,設置根用戶密碼並映射端口驗證連接創建數據庫和用戶授予對數據庫的所有權限

docker怎麼更新鏡像 docker怎麼更新鏡像 Apr 15, 2025 pm 12:03 PM

更新 Docker 鏡像的步驟如下:拉取最新鏡像標記新鏡像為特定標籤刪除舊鏡像(可選)重新啟動容器(如果需要)

docker怎麼啟動容器 docker怎麼啟動容器 Apr 15, 2025 pm 12:27 PM

Docker 容器啟動步驟:拉取容器鏡像:運行 "docker pull [鏡像名稱]"。創建容器:使用 "docker create [選項] [鏡像名稱] [命令和參數]"。啟動容器:執行 "docker start [容器名稱或 ID]"。檢查容器狀態:通過 "docker ps" 驗證容器是否正在運行。

docker怎麼創建容器 docker怎麼創建容器 Apr 15, 2025 pm 12:18 PM

在 Docker 中創建容器: 1. 拉取鏡像: docker pull [鏡像名] 2. 創建容器: docker run [選項] [鏡像名] [命令] 3. 啟動容器: docker start [容器名]

See all articles