日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長(zhǎng)提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

目錄
  • 什么是聯(lián)合文件系統(tǒng)
  • 如何配置 Docker 的 AUFS 模式
  • AUFS 工作原理
    • AUFS 是如何存儲(chǔ)文件的?
    • AUFS 是如何工作的?
    • 1. 讀取文件
    • 修改文件或目錄
  • AUFS 演示
    • 準(zhǔn)備演示目錄和文件
    • 創(chuàng)建 AUFS 聯(lián)合文件系統(tǒng)
    • 驗(yàn)證 AUFS 的寫(xiě)時(shí)復(fù)制
  • 結(jié)語(yǔ)

    前言:

    我們知道,Docker 主要是基于 Namespace、cgroups 和聯(lián)合文件系統(tǒng)這三大核心技術(shù)實(shí)現(xiàn)的。前面的課時(shí)我詳細(xì)講解了 Namespace 和 cgroups 的相關(guān)原理,那么你知道聯(lián)合文件系統(tǒng)是什么嗎?它的原理又是什么呢?
    首先我們來(lái)了解一下什么是聯(lián)合文件系統(tǒng)。

    什么是聯(lián)合文件系統(tǒng)

    聯(lián)合文件系統(tǒng)(Union File System,Unionfs)是一種分層的輕量級(jí)文件系統(tǒng),它可以把多個(gè)目錄內(nèi)容聯(lián)合掛載到同一目錄下,從而形成一個(gè)單一的文件系統(tǒng),這種特性可以讓使用者像是使用一個(gè)目錄一樣使用聯(lián)合文件系統(tǒng)。
    那聯(lián)合文件系統(tǒng)對(duì)于 Docker 是一個(gè)怎樣的存在呢?它可以說(shuō)是 Docker 鏡像和容器的基礎(chǔ),因?yàn)樗梢允?Docker 可以把鏡像做成分層的結(jié)構(gòu),從而使得鏡像的每一層可以被共享。例如兩個(gè)業(yè)務(wù)鏡像都是基于 CentOS 7 鏡像構(gòu)建的,那么這兩個(gè)業(yè)務(wù)鏡像在物理機(jī)上只需要存儲(chǔ)一次 CentOS 7 這個(gè)基礎(chǔ)鏡像即可,從而節(jié)省大量存儲(chǔ)空間。
    說(shuō)到這兒,你有沒(méi)有發(fā)現(xiàn),聯(lián)合文件系統(tǒng)只是一個(gè)概念,真正實(shí)現(xiàn)聯(lián)合文件系統(tǒng)才是關(guān)鍵,那如何實(shí)現(xiàn)呢?其實(shí)實(shí)現(xiàn)方案有很多,Docker 中最常用的聯(lián)合文件系統(tǒng)有三種:AUFS、Devicemapper 和 OverlayFS。
    今天我主要講解 Docker 中最常用的聯(lián)合文件系統(tǒng)里的 AUFS,為什么呢?因?yàn)?AUFS 是 Docker 最早使用的文件系統(tǒng)驅(qū)動(dòng),多用于 Ubuntu 和 Debian 系統(tǒng)中。在 Docker 早期,OverlayFS 和 Devicemapper 相對(duì)不夠成熟,AUFS 是最早也是最穩(wěn)定的文件系統(tǒng)驅(qū)動(dòng)。 Devicemapper 和 OverlayFS 聯(lián)合文件系統(tǒng)。
    接下來(lái),我們就看看如何配置 Docker 的 AUFS 模式。

    如何配置 Docker 的 AUFS 模式

    AUFS 目前并未被合并到 Linux 內(nèi)核主線,因此只有 Ubuntu 和 Debian 等少數(shù)操作系統(tǒng)支持 AUFS。

    我們可以使用以下命令查看你的系統(tǒng)是否支持 AUFS:

    $ grep aufs /proc/filesystems
    nodev aufs

    執(zhí)行以上命令后,如果輸出結(jié)果包含??aufs??,則代表當(dāng)前操作系統(tǒng)支持 AUFS。AUFS 推薦在 Ubuntu 或 Debian 操作系統(tǒng)下使用,如果你想要在 CentOS 等操作系統(tǒng)下使用 AUFS,需要單獨(dú)安裝 AUFS 模塊(生產(chǎn)環(huán)境不推薦在 CentOS 下使用 AUFS,如果你想在 CentOS 下安裝 AUFS 用于研究和測(cè)試,可以參考這個(gè)? ?鏈接??),安裝完成后使用上述命令輸出結(jié)果中有??aufs??即可。

    當(dāng)確認(rèn)完操作系統(tǒng)支持 AUFS 后,你就可以配置 Docker 的啟動(dòng)參數(shù)了。

    先在 /etc/docker 下新建 daemon.json 文件,并寫(xiě)入以下內(nèi)容:

    {
    "storage-driver": "aufs"
    }

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

    $ sudo systemctl restart docker

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

    $ sudo docker info
    Client:
    Debug Mode: false
    Server:
    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 已經(jīng)變?yōu)?aufs,證明配置已經(jīng)生效,配置生效后就可以使用 AUFS 為 Docker 提供聯(lián)合文件系統(tǒng)了。
    配置好 Docker 的 AUFS 聯(lián)合文件系統(tǒng)后,你一定很好奇 AUFS 到底是如何工作的呢?下面我?guī)阍敿?xì)學(xué)習(xí)一下 AUFS 的工作原理。

    AUFS 工作原理

    AUFS 是如何存儲(chǔ)文件的?

    AUFS 是聯(lián)合文件系統(tǒng),意味著它在主機(jī)上使用多層目錄存儲(chǔ),每一個(gè)目錄在 AUFS 中都叫作分支,而在 Docker 中則稱之為層(layer),但最終呈現(xiàn)給用戶的則是一個(gè)普通單層的文件系統(tǒng),我們把多層以單一層的方式呈現(xiàn)出來(lái)的過(guò)程叫作聯(lián)合掛載。

    Docker?文件系統(tǒng)-AUFS?原理介紹

    如上圖,每一個(gè)鏡像層和容器層都是 /var/lib/docker 下的一個(gè)子目錄,鏡像層和容器層都在 aufs/diff 目錄下,每一層的目錄名稱是鏡像或容器的 ID 值,聯(lián)合掛載點(diǎn)在 aufs/mnt 目錄下,mnt 目錄是真正的容器工作目錄。
    下面我們針對(duì) aufs 文件夾下的各目錄結(jié)構(gòu),在創(chuàng)建容器前后的變化做詳細(xì)講述。
    當(dāng)一個(gè)鏡像未生成容器時(shí),AUFS 的存儲(chǔ)結(jié)構(gòu)如下。

    • diff 文件夾:存儲(chǔ)鏡像內(nèi)容,每一層都存儲(chǔ)在以鏡像層 ID 命名的子文件夾中。
    • layers 文件夾:存儲(chǔ)鏡像層關(guān)系的元數(shù)據(jù),在 diff 文件夾下的每個(gè)鏡像層在這里都會(huì)有一個(gè)文件,文件的內(nèi)容為該層鏡像的父級(jí)鏡像的 ID。
    • mnt 文件夾:聯(lián)合掛載點(diǎn)目錄,未生成容器時(shí),該目錄為空。

    當(dāng)一個(gè)鏡像已經(jīng)生成容器時(shí),AUFS 存儲(chǔ)結(jié)構(gòu)會(huì)發(fā)生如下變化。

    • diff 文件夾:當(dāng)容器運(yùn)行時(shí),會(huì)在 diff 目錄下生成容器層。
    • layers 文件夾:增加容器層相關(guān)的元數(shù)據(jù)。
    • mnt 文件夾:容器的聯(lián)合掛載點(diǎn),這和容器中看到的文件內(nèi)容一致。

    以上便是 AUFS 的工作原理,那你知道容器的在工作過(guò)程中是如何使用 AUFS 的嗎?

    AUFS 是如何工作的?

    AUFS 的工作過(guò)程中對(duì)文件的操作分為讀取文件和修改文件。下面我們分別來(lái)看下 AUFS 對(duì)于不同的文件操作是如何工作的。

    1. 讀取文件

    當(dāng)我們?cè)谌萜髦凶x取文件時(shí),可能會(huì)有以下場(chǎng)景。

    • 文件在容器層中存在時(shí):當(dāng)文件存在于容器層時(shí),直接從容器層讀取。
    • 當(dāng)文件在容器層中不存在時(shí):當(dāng)容器運(yùn)行時(shí)需要讀取某個(gè)文件,如果容器層中不存在時(shí),則從鏡像層查找該文件,然后讀取文件內(nèi)容。
    • 文件既存在于鏡像層,又存在于容器層:當(dāng)我們讀取的文件既存在于鏡像層,又存在于容器層時(shí),將會(huì)從容器層讀取該文件。

    修改文件或目錄

    AUFS 對(duì)文件的修改采用的是寫(xiě)時(shí)復(fù)制的工作機(jī)制,這種工作機(jī)制可以最大程度節(jié)省存儲(chǔ)空間。
    具體的文件操作機(jī)制如下。

    • 第一次修改文件:當(dāng)我們第一次在容器中修改某個(gè)文件時(shí),AUFS 會(huì)觸發(fā)寫(xiě)時(shí)復(fù)制操作,AUFS 首先從鏡像層復(fù)制文件到容器層,然后再執(zhí)行對(duì)應(yīng)的修改操作。

    AUFS 寫(xiě)時(shí)復(fù)制的操作將會(huì)復(fù)制整個(gè)文件,如果文件過(guò)大,將會(huì)大大降低文件系統(tǒng)的性能,因此當(dāng)我們有大量文件需要被修改時(shí),AUFS 可能會(huì)出現(xiàn)明顯的延遲。好在,寫(xiě)時(shí)復(fù)制操作只在第一次修改文件時(shí)觸發(fā),對(duì)日常使用沒(méi)有太大影響。

    • 刪除文件或目錄:當(dāng)文件或目錄被刪除時(shí),AUFS 并不會(huì)真正從鏡像中刪除它,因?yàn)殓R像層是只讀的,AUFS 會(huì)創(chuàng)建一個(gè)特殊的文件或文件夾,這種特殊的文件或文件夾會(huì)阻止容器的訪問(wèn)。

    下面我們通過(guò)一個(gè)實(shí)例來(lái)演示一下 AUFS 。

    AUFS 演示

    準(zhǔn)備演示目錄和文件

    首先我們?cè)?/tmp 目錄下創(chuàng)建 aufs 目錄:

    $ cd /tmp
    /tmp$ mkdir aufs

    準(zhǔn)備掛載點(diǎn)目錄:

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

    接下來(lái)準(zhǔn)備容器層內(nèi)容:

    ## 創(chuàng)建鏡像層目錄
    /tmp/aufs$ mkdir container1
    ## 在鏡像層目錄下準(zhǔn)備一個(gè)文件
    /tmp/aufs$ echo Hello, Container layer! > container1/container1.txt

    最后準(zhǔn)備鏡像層內(nèi)容:

    ## 創(chuàng)建兩個(gè)鏡像層目錄
    /tmp/aufs$ mkdir image1 && mkdir image2
    ## 分別寫(xiě)入數(shù)據(jù)
    /tmp/aufs$ echo Hello, Image layer1! > image1/image1.txt
    /tmp/aufs$ echo Hello, Image layer2! > image2/image2.txt

    準(zhǔn)備好的目錄和文件結(jié)構(gòu)如下:

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

    創(chuàng)建 AUFS 聯(lián)合文件系統(tǒng)

    使用 mount 命令可以創(chuàng)建 AUFS 類型的文件系統(tǒng),命令如下:

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

    mount 命令創(chuàng)建 AUFS 類型文件系統(tǒng)時(shí),這里要注意,dirs 參數(shù)第一個(gè)冒號(hào)默認(rèn)為讀寫(xiě)權(quán)限,后面的目錄均為只讀權(quán)限,與 Docker 容器使用 AUFS 的模式一致。

    執(zhí)行完上述命令后,mnt 變成了 AUFS 的聯(lián)合掛載目錄,我們可以使用 mount 命令查看一下已經(jīng)創(chuàng)建的 AUFS 文件系統(tǒng):

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

    我們每創(chuàng)建一個(gè) AUFS 文件系統(tǒng),AUFS 都會(huì)為我們生成一個(gè) ID,這個(gè) ID 在 /sys/fs/aufs/ 會(huì)創(chuàng)建對(duì)應(yīng)的目錄,在這個(gè) ID 的目錄下可以查看文件掛載的權(quán)限。

    tmp/aufs$ cat /sys/fs/aufs/si_4174b83d649ffb7c/*
    /tmp/aufs/container1=rw
    /tmp/aufs/image2=ro
    /tmp/aufs/image1=ro
    64
    65
    66

    可以看到 container1 目錄的權(quán)限為 rw(代表可讀寫(xiě)),image1 和 image2 的權(quán)限為 ro(代表只讀)。
    為了驗(yàn)證 mnt 目錄下可以看到 container1、image1 和 image2 目錄下的所有內(nèi)容,我們使用 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 目錄下已經(jīng)出現(xiàn)了我們準(zhǔn)備的所有鏡像層和容器層的文件。下面讓我們來(lái)驗(yàn)證一下 AUFS 的寫(xiě)時(shí)復(fù)制。

    驗(yàn)證 AUFS 的寫(xiě)時(shí)復(fù)制

    AUFS 的寫(xiě)時(shí)復(fù)制是指在容器中,只有需要修改某個(gè)文件時(shí),才會(huì)把文件從鏡像層復(fù)制到容器層,下面我們通過(guò)修改聯(lián)合掛載目錄 mnt 下的內(nèi)容來(lái)驗(yàn)證下這個(gè)過(guò)程。

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

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

    然后我們查看下 image1/image1.txt 文件內(nèi)容:

    /tmp/aufs$ cat image1/image1.txt
    Hello, Image layer1!

    發(fā)現(xiàn)“鏡像層”的 image1.txt 文件并未被修改。

    然后我們查看一下"容器層"對(duì)應(yīng)的 image1.txt 文件內(nèi)容:

    /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
    ## 查看文件內(nèi)容
    /tmp/aufs$ cat container1/image1.txt
    Hello, Image layer1 changed!

    發(fā)現(xiàn) AUFS 在“容器層”自動(dòng)創(chuàng)建了 image1.txt 文件,并且內(nèi)容為我們剛才寫(xiě)入的內(nèi)容。
    至此,我們完成了 AUFS 寫(xiě)時(shí)復(fù)制的驗(yàn)證。我們?cè)诘谝淮涡薷溺R像內(nèi)某個(gè)文件時(shí),AUFS 會(huì)復(fù)制這個(gè)文件到容器層,然后在容器層對(duì)該文件進(jìn)行修改操作,這就是 AUFS 最典型的特性寫(xiě)時(shí)復(fù)制。

    結(jié)語(yǔ)

    相信你知道了聯(lián)合文件系統(tǒng)是一種分層的輕量級(jí)文件系統(tǒng),它可以把多個(gè)目錄內(nèi)容聯(lián)合掛載到同一目錄下,從而形成一個(gè)單一的文件系統(tǒng)。同時(shí)也學(xué)會(huì)了如何配置 Docker 使用 AUFS ,并且明白了 AUFS 的工作原理。

    分享到:
    標(biāo)簽:Docker 介紹 原理 文件系統(tǒng) 服務(wù)器
    用戶無(wú)頭像

    網(wǎng)友整理

    注冊(cè)時(shí)間:

    網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

    • 51998

      網(wǎng)站

    • 12

      小程序

    • 1030137

      文章

    • 747

      會(huì)員

    趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
    最新入駐小程序

    數(shù)獨(dú)大挑戰(zhàn)2018-06-03

    數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

    答題星2018-06-03

    您可以通過(guò)答題星輕松地創(chuàng)建試卷

    全階人生考試2018-06-03

    各種考試題,題庫(kù),初中,高中,大學(xué)四六

    運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

    記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

    每日養(yǎng)生app2018-06-03

    每日養(yǎng)生,天天健康

    體育訓(xùn)練成績(jī)?cè)u(píng)定2018-06-03

    通用課目體育訓(xùn)練成績(jī)?cè)u(píng)定