0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Linux overlayfs文件系統(tǒng)概述

Linux閱碼場(chǎng) ? 來源:Linux閱碼場(chǎng) ? 作者:Linux閱碼場(chǎng) ? 2021-10-20 10:21 ? 次閱讀

OverlayFS,顧名思義是一種堆疊文件系統(tǒng),可以將多個(gè)目錄的內(nèi)容疊加到另一個(gè)目錄上。OverlayFS并不直接涉及磁盤空間結(jié)構(gòu),看起來像是將多個(gè)目錄的文件按照規(guī)則合并到同一個(gè)目錄。且對(duì)多個(gè)源目錄具體使用文件系統(tǒng)類型沒有要求,即使各個(gè)源目錄的文件系統(tǒng)類型不同也不影響使用。

一、掛載OverlayFS

下面就讓我們來看看如何掛載一個(gè)OverlayFS文件系統(tǒng):

mount-t overlay -o lowerdir=/lower,upperdir=/upper,workdir=/work overlay /merged

上面的命令可以將“l(fā)owerdir”和“upper”目錄堆疊到/merged目錄,“workdir”工作目錄要求是和“upperdir”目錄同一類型文件系統(tǒng)的空目錄。

也可以省略u(píng)pperdir和workdir參數(shù),但/merged為只讀屬性了:

mount-t overlay -o lowerdir=/upper:/lower overlay /merged

也可支持多l(xiāng)owerdir目錄堆疊:

mount-t overlay -o lowerdir=/lower1:/lower2:/lower3,upperdir=/upper,workdir=/workoverlay /merged

lowerdir的多層目錄使用“:”分隔開,其中層級(jí)關(guān)系為/lower1》 /lower2 》 /lower3。

在使用如上mount進(jìn)行OverlayFS合并之后,遵循如下規(guī)則:? lowerdir和upperdir兩個(gè)目錄存在同名文件時(shí),lowerdir的文件將會(huì)被隱藏,用戶只能看到upperdir的文件。

? lowerdir低優(yōu)先級(jí)的同目錄同名文件將會(huì)被隱藏。? 如果存在同名目錄,那么lowerdir和upperdir目錄中的內(nèi)容將會(huì)合并。

? 當(dāng)用戶修改mergedir中來自u(píng)pperdir的數(shù)據(jù)時(shí),數(shù)據(jù)將直接寫入upperdir中原來目錄中,刪除文件也同理。

? 當(dāng)用戶修改mergedir中來自lowerdir的數(shù)據(jù)時(shí),lowerdir中內(nèi)容均不會(huì)發(fā)生任何改變。因?yàn)閘owerdir是只讀的,用戶想修改來自lowerdir數(shù)據(jù)時(shí),overlayfs會(huì)首先拷貝一份lowerdir中文件副本到upperdir中(這也被稱作OverlayFS的copy-up特性)。后續(xù)修改或刪除將會(huì)在upperdir下的副本中進(jìn)行,lowerdir中原文件將會(huì)被隱藏。

? 如果某一個(gè)目錄單純來自lowerdir或者lowerdir和upperdir合并,默認(rèn)無法進(jìn)行rename系統(tǒng)調(diào)用。但是可以通過mv重命名。如果要支持rename,需要CONFIG_OVERLAY_FS_REDIRECT_DIR。

一般lowerdir為只讀文件系統(tǒng),upperdir為可寫文件系統(tǒng),這形成了一個(gè)有趣的機(jī)制,似乎我們可以修改lowerdir下的文件或目錄,lowerdir看上去變成了一個(gè)可讀寫的文件系統(tǒng)。

二、刪除文件和目錄

為了支持rm和rmdir而又不修改lower文件系統(tǒng),需要在upper文件系統(tǒng)中記錄文件或目錄已經(jīng)被刪除。OverlayFS引入了whiteout文件的概念。如果需要?jiǎng)h除lower層的文件或目錄,需要在upper層創(chuàng)建一個(gè)whiteout文件。

ecc091b4-3101-11ec-82a8-dac502259ad0.png

可以看到刪除merged目錄下的文件或目錄后,在upper層新建了aa、bb、dir三個(gè)whiteout文件,whiteout文件不是普通文件,而是主/次設(shè)備號(hào)都是0的字符設(shè)備。只存在于upper的文件cc直接刪除就可以了。

三、創(chuàng)建文件和目錄

創(chuàng)建操作與刪除操作類似,都是在upper層進(jìn)行修改。創(chuàng)建文件直接在upper層新增文件即可,如果upper層存在對(duì)應(yīng)的whiteout文件,先刪除whiteout文件再創(chuàng)建文件。創(chuàng)建目錄與創(chuàng)建文件類似,區(qū)別在于upper層存在whiteout文件時(shí),刪掉whiteout文件創(chuàng)建目錄,如果就此結(jié)束,lower層對(duì)應(yīng)目錄(因?yàn)橛衱hiteout文件)的文件就被顯示到merged目錄了,所以還需要將目錄的“trusted.overlay.opaque”屬性設(shè)為“y”(所以這也就需要upper層所在的文件系統(tǒng)支持xattr擴(kuò)展屬性),OverlayFS在讀取上下層存在同名目錄的目錄項(xiàng)時(shí),如果upper層的目錄被設(shè)置了opaque屬性,它將忽略這個(gè)目錄下層的所有同名目錄中的目錄項(xiàng),以保證新建的目錄是一個(gè)空的目錄。

ed06132e-3101-11ec-82a8-dac502259ad0.png

四、rename目錄

當(dāng)我們想重命名一個(gè)在lower層的目錄,OverlayFS有兩種處理方式:

1. 返回EXDEV錯(cuò)誤碼:rename系統(tǒng)調(diào)用試圖穿過文件系統(tǒng)邊界移動(dòng)一個(gè)文件或目錄時(shí)返回這個(gè)錯(cuò)誤。這個(gè)是默認(rèn)行為。

2. 當(dāng)使能“redirect_dir”特性后,rename操作成功,在upper層產(chǎn)生一個(gè)副本目錄。

有以下幾種方式控制“redirect_dir”特性:

1. KernelConfig Options:

? OVERLAY_FS_REDIRECT_DIR

? OVERLAY_FS_REDIRECT_ALWAYS_FOLLOW

使能后,redirect_dir特性默認(rèn)打開。

2. sys文件系統(tǒng):

參照KernelConfig設(shè)置:

/sys/module/overlay/parameters/redirect_dir

/sys/module/overlay/parameters/redirect_always_follow

/sys/module/overlay/parameters/redirect_max

3. MountOptions:

redirect_dir=on/off/follow/nofollow

五、Android中的應(yīng)用

OverlayFS文件系統(tǒng)可以類似達(dá)到把只讀文件系統(tǒng)改為可寫文件系統(tǒng)的效果,這一特性在Android開發(fā)的場(chǎng)景下得到應(yīng)用,userdebug模式下我們adbremount后似乎就可以往/system/目錄下push內(nèi)容了,查看remount前后的mount信息,可以看到/system/目錄被重新掛載成可讀寫的OverlayFS文件系統(tǒng)了:

remount前:

ed733f6c-3101-11ec-82a8-dac502259ad0.png

remount后:

ede5d8ec-3101-11ec-82a8-dac502259ad0.png

重啟:

ee59c9a0-3101-11ec-82a8-dac502259ad0.png

system、vendor、product等目錄是以ext4文件系統(tǒng)方式掛載的,remount后以O(shè)verlayFS掛載,之后重啟也會(huì)以O(shè)verlayFS方式掛載,以使之前的修改生效。

system和vendor等的upperdir都在/cache可寫文件系統(tǒng)中,往/system目錄push東西實(shí)際上都存放在/cache/overlay/system/upper目錄中了。實(shí)際的system分區(qū)并沒有被修改,修改的文件全部存放在cache分區(qū)了。

OverlayFS也被應(yīng)用在把多個(gè)不同分區(qū)的目錄堆疊到一個(gè)目錄下面,可以更好做到軟件系統(tǒng)的組件解耦,不同特性的組件內(nèi)容分別放到不同分區(qū),最后通過OverlayFS堆疊到一個(gè)目錄下,提升軟件的可維護(hù)性。

六、小結(jié)

OverlayFS以其獨(dú)特的優(yōu)勢(shì)正得到越來越廣泛的應(yīng)用,Androiduserdebug/eng模式中使用其實(shí)現(xiàn)對(duì)系統(tǒng)分區(qū)的修改。OpenWRT系統(tǒng)也利用OverlayFS減少擦寫閃存的次數(shù),延長閃存的使用壽命。OverlayFS更多的應(yīng)用在云平臺(tái)的容器鏡像,基礎(chǔ)的容器鏡像通常不應(yīng)被改變,新功能疊加可以通過OverlayFS實(shí)現(xiàn)且可以再次分發(fā)。

參考文獻(xiàn)

1. https://www.kernel.org/doc/html/latest/filesystems/overlayfs.html

2. https://blog.csdn.net/luckyapple1028/article/details/78075358

編輯:jq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11304

    瀏覽量

    209535
  • 云平臺(tái)
    +關(guān)注

    關(guān)注

    1

    文章

    1307

    瀏覽量

    38957

原文標(biāo)題:Linux overlayfs文件系統(tǒng)介紹

文章出處:【微信號(hào):LinuxDev,微信公眾號(hào):Linux閱碼場(chǎng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    Jtti:Linux中虛擬文件系統(tǒng)和容器化的關(guān)系

    Linux中,虛擬文件系統(tǒng)(VFS)和容器化技術(shù)之間有密切的關(guān)系。容器化是指通過使用容器來運(yùn)行應(yīng)用程序,而容器本質(zhì)上是在宿主機(jī)上運(yùn)行的獨(dú)立進(jìn)程,它們通常共享宿主機(jī)的操作系統(tǒng)內(nèi)核和部分文件系統(tǒng)
    的頭像 發(fā)表于 11-27 15:38 ?152次閱讀

    Linux文件系統(tǒng)的掛載過程

    Linux文件系統(tǒng)(rootfs)是Linux系統(tǒng)中所有其他文件系統(tǒng)和目錄的起點(diǎn),它是內(nèi)核啟動(dòng)時(shí)掛載的第一個(gè)
    的頭像 發(fā)表于 10-05 16:50 ?428次閱讀

    如何構(gòu)建Linux文件系統(tǒng)

    構(gòu)建Linux文件系統(tǒng)是一個(gè)涉及多個(gè)步驟和概念的過程,它對(duì)于Linux系統(tǒng)的啟動(dòng)和運(yùn)行至關(guān)重要。
    的頭像 發(fā)表于 10-05 16:47 ?304次閱讀

    小型文件系統(tǒng)如何選擇?FatFs和LittleFs優(yōu)缺點(diǎn)比較

    01? 概述 文件系統(tǒng)在嵌入式系統(tǒng)中的作用不可或缺,它提供了對(duì)非易失性存儲(chǔ)設(shè)備(如閃存、SD卡等)上的數(shù)據(jù)進(jìn)行有效組織和管理的能力。通過文件系統(tǒng),嵌入式
    的頭像 發(fā)表于 09-29 16:14 ?1689次閱讀
    小型<b class='flag-5'>文件系統(tǒng)</b>如何選擇?FatFs和LittleFs優(yōu)缺點(diǎn)比較

    ubuntu刪除的文件怎么恢復(fù)

    : Ubuntu文件系統(tǒng)概述 Ubuntu是一個(gè)基于Linux的操作系統(tǒng),其文件系統(tǒng)與Windows系統(tǒng)
    的頭像 發(fā)表于 08-30 15:10 ?1457次閱讀

    服務(wù)器數(shù)據(jù)恢復(fù)—xfs文件系統(tǒng)服務(wù)器數(shù)據(jù)恢復(fù)案例

    某公司一臺(tái)服務(wù)器,連接了一臺(tái)存儲(chǔ)。該服務(wù)器安裝linux操作系統(tǒng),文件系統(tǒng)為xfs。 在運(yùn)行過程中該服務(wù)器出現(xiàn)故障,管理員使用xfs_repair工具試圖對(duì)xfs文件系統(tǒng)進(jìn)行修復(fù)但失
    的頭像 發(fā)表于 08-19 10:49 ?299次閱讀

    如何更改Linux文件系統(tǒng)終端顯示顏色

    自己制作的簡單 Linux 文件系統(tǒng),你會(huì)發(fā)現(xiàn)終端顯示為黑白色,很不好看
    的頭像 發(fā)表于 08-12 17:29 ?553次閱讀
    如何更改<b class='flag-5'>Linux</b><b class='flag-5'>文件系統(tǒng)</b>終端顯示顏色

    如何修改buildroot和debian文件系統(tǒng)

    本文檔主要介紹在沒有編譯環(huán)境的情況下,如何修改buildroot和debian文件系統(tǒng)方法,如在buildroot文件系統(tǒng)中添加文件、修改目錄等文件操作,在debian
    的頭像 發(fā)表于 07-22 17:46 ?495次閱讀
    如何修改buildroot和debian<b class='flag-5'>文件系統(tǒng)</b>

    Linux高級(jí)文件系統(tǒng)管理詳解

    階的文件系統(tǒng)就得要學(xué)習(xí),本章我們會(huì)介紹磁盤陣列 (RAID),及邏輯卷軸文件系統(tǒng) (LVM),這些工具都可以幫助你管理與維護(hù)使用者可用的磁盤容量.
    的頭像 發(fā)表于 07-16 16:31 ?363次閱讀

    linux--sysfs文件系統(tǒng)

    sysfs文件系統(tǒng) sysfs,全稱為System Filesystem,是一個(gè)由Linux內(nèi)核實(shí)現(xiàn)的虛擬文件系統(tǒng)。它扮演著一個(gè)橋梁的角色,將內(nèi)核中的設(shè)備和驅(qū)動(dòng)程序信息以文件的形式呈現(xiàn)
    的頭像 發(fā)表于 07-08 11:37 ?879次閱讀
    <b class='flag-5'>linux</b>--sysfs<b class='flag-5'>文件系統(tǒng)</b>

    【嵌入式SD NAND】基于FATFS/Littlefs文件系統(tǒng)的日志框架實(shí)現(xiàn)

    文章目錄 【嵌入式】基于FATFS/Littlefs文件系統(tǒng)的日志框架實(shí)現(xiàn) 1. 概述 2. 設(shè)計(jì)概要 3. 設(shè)計(jì)實(shí)現(xiàn) 3.1 初始化 `init` 3.2 日志寫入 `write` 3.3 日志
    的頭像 發(fā)表于 03-14 18:13 ?1064次閱讀
    【嵌入式SD NAND】基于FATFS/Littlefs<b class='flag-5'>文件系統(tǒng)</b>的日志框架實(shí)現(xiàn)

    【嵌入式SD NAND】基于FATFS/Littlefs文件系統(tǒng)的日志框架實(shí)現(xiàn)

    文章目錄【嵌入式】基于FATFS/Littlefs文件系統(tǒng)的日志框架實(shí)現(xiàn)1.概述2.設(shè)計(jì)概要3.設(shè)計(jì)實(shí)現(xiàn)3.1初始化`init`3.2日志寫入`write`3.3日志讀取`read`3.4注銷
    的頭像 發(fā)表于 03-14 18:12 ?1161次閱讀
    【嵌入式SD NAND】基于FATFS/Littlefs<b class='flag-5'>文件系統(tǒng)</b>的日志框架實(shí)現(xiàn)

    Linux系統(tǒng)如何擴(kuò)展文件系統(tǒng)

    當(dāng)數(shù)據(jù)盤沒有創(chuàng)建分區(qū),只在設(shè)備上創(chuàng)建了文件系統(tǒng)?;蛘吒袷交擞脖P,就直接mount上系統(tǒng)使用。
    的頭像 發(fā)表于 02-21 09:53 ?842次閱讀

    鴻蒙輕內(nèi)核源碼分析:虛擬文件系統(tǒng) VFS

    VFS(Virtual File System)是文件系統(tǒng)的虛擬層,它不是一個(gè)實(shí)際的文件系統(tǒng),而是一個(gè)異構(gòu)文件系統(tǒng)之上的軟件粘合層,為用戶提供統(tǒng)一的類 Unix 文件操作接口。由于不同
    的頭像 發(fā)表于 02-18 14:50 ?828次閱讀

    如何使用squashfs只讀文件系統(tǒng)制作Linux系統(tǒng)文件

    在 Colibri iMX6 的 eMMC 上我們將使用以下分區(qū)規(guī)劃。BootFS 為 FAT32 格式,該分區(qū)上包含 Linux 內(nèi)核文件,device tree 等啟動(dòng)文件,如果是 iMX8,則還包含一些其他固件
    發(fā)表于 01-09 11:43 ?1992次閱讀
    如何使用squashfs只讀<b class='flag-5'>文件系統(tǒng)</b>制作<b class='flag-5'>Linux</b><b class='flag-5'>系統(tǒng)</b><b class='flag-5'>文件</b>