chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

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

Linux閱碼場 ? 來源:Linux閱碼場 ? 作者:Linux閱碼場 ? 2021-10-20 10:21 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

一、掛載OverlayFS

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

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

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

也可以省略upperdir和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的多層目錄使用“:”分隔開,其中層級關(guān)系為/lower1》 /lower2 》 /lower3。

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

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

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

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

? 如果某一個目錄單純來自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),這形成了一個有趣的機(jī)制,似乎我們可以修改lowerdir下的文件或目錄,lowerdir看上去變成了一個可讀寫的文件系統(tǒng)。

二、刪除文件和目錄

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

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

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

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

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

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

四、rename目錄

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

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

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

有以下幾種方式控制“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ā)的場景下得到應(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掛載,之后重啟也會以O(shè)verlayFS方式掛載,以使之前的修改生效。

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

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

六、小結(jié)

OverlayFS以其獨(dú)特的優(yōu)勢正得到越來越廣泛的應(yīng)用,Androiduserdebug/eng模式中使用其實(shí)現(xiàn)對系統(tǒng)分區(qū)的修改。OpenWRT系統(tǒng)也利用OverlayFS減少擦寫閃存的次數(shù),延長閃存的使用壽命。OverlayFS更多的應(yīng)用在云平臺的容器鏡像,基礎(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)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Linux
    +關(guān)注

    關(guān)注

    88

    文章

    11746

    瀏覽量

    218903
  • 云平臺
    +關(guān)注

    關(guān)注

    1

    文章

    1548

    瀏覽量

    42072

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

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    明晚8點(diǎn)|睿擎文件系統(tǒng)實(shí)戰(zhàn):從開發(fā)到發(fā)布全流程解析

    文件操作到鏡像發(fā)布,一次直播掌握完整開發(fā)流程!在嵌入式系統(tǒng)開發(fā)中,文件系統(tǒng)是數(shù)據(jù)存儲、配置管理和資源訪問的核心基礎(chǔ)。然而在實(shí)際開發(fā)中,文件操作效率低下、鏡像打包流程復(fù)雜、
    的頭像 發(fā)表于 11-11 11:53 ?621次閱讀
    明晚8點(diǎn)|睿擎<b class='flag-5'>文件系統(tǒng)</b>實(shí)戰(zhàn):從開發(fā)到發(fā)布全流程解析

    【直播預(yù)告】下周三晚8點(diǎn)|睿擎文件系統(tǒng)實(shí)戰(zhàn):從開發(fā)到發(fā)布全流程解析

    文件操作到鏡像發(fā)布,一次直播掌握完整開發(fā)流程!在嵌入式系統(tǒng)開發(fā)中,文件系統(tǒng)是數(shù)據(jù)存儲、配置管理和資源訪問的核心基礎(chǔ)。然而在實(shí)際開發(fā)中,文件操作效率低下、鏡像打包流程復(fù)雜、
    的頭像 發(fā)表于 11-06 18:05 ?1882次閱讀
    【直播預(yù)告】下周三晚8點(diǎn)|睿擎<b class='flag-5'>文件系統(tǒng)</b>實(shí)戰(zhàn):從開發(fā)到發(fā)布全流程解析

    睿擎派文件系統(tǒng)指南:從開發(fā)到發(fā)布全流程實(shí)踐 | 技術(shù)解析

    在嵌入式系統(tǒng)開發(fā)中,文件系統(tǒng)扮演著至關(guān)重要的角色,它負(fù)責(zé)數(shù)據(jù)的持久化存儲、配置文件管理和資源訪問等核心功能。睿擎平臺提供了一套完整的文件系統(tǒng)解決方案,從開發(fā)階段的API調(diào)用到調(diào)試階段的
    的頭像 發(fā)表于 11-05 18:13 ?8057次閱讀
    睿擎派<b class='flag-5'>文件系統(tǒng)</b>指南:從開發(fā)到發(fā)布全流程實(shí)踐 | 技術(shù)解析

    如何在 nuc980 上切換到持久文件系統(tǒng)?

    我遵循了“NUC980 Linux 4.4 BSP 用戶手冊EN.pdf”文檔,但當(dāng)我嘗試取消選擇“初始 RAM 文件系統(tǒng)和 RAM 磁盤 (initramfs/initrd) 支持
    發(fā)表于 08-29 07:58

    Linux三大主流文件系統(tǒng)解析

    還在為選擇哪個文件系統(tǒng)而糾結(jié)?作為一名摸爬滾打多年的運(yùn)維老鳥,我將用最接地氣的方式,帶你徹底搞懂 Linux 三大主流文件系統(tǒng)的奧秘。
    的頭像 發(fā)表于 08-05 17:37 ?1380次閱讀

    Linux系統(tǒng)目錄結(jié)構(gòu)全面剖析

    Linux文件系統(tǒng)采用層次化的目錄結(jié)構(gòu),這種設(shè)計(jì)遵循了Unix哲學(xué)中的"一切皆文件"原則。理解Linux目錄層次架構(gòu)對于系統(tǒng)管理員、運(yùn)維工程
    的頭像 發(fā)表于 07-21 17:33 ?757次閱讀

    飛凌嵌入式ElfBoard ELF 1板卡-文件系統(tǒng)簡介

    9.1 文件系統(tǒng)概念文件系統(tǒng)通常提供目錄或文件夾用于記錄文件,在很多系統(tǒng)中目錄本身也是文件,在這
    發(fā)表于 06-19 17:22

    服務(wù)器數(shù)據(jù)恢復(fù)—重裝系統(tǒng)導(dǎo)致XFS文件系統(tǒng)分區(qū)丟失的數(shù)據(jù)恢復(fù)案例

    服務(wù)器數(shù)據(jù)恢復(fù)環(huán)境&故障: 一臺服務(wù)器上通過磁盤柜+RAID卡組建的riad5磁盤陣列,服務(wù)器上層安裝Linux操作系統(tǒng),搭建XFS文件系統(tǒng)。服務(wù)器上層分配一個LUN,并劃分了兩個分區(qū)
    的頭像 發(fā)表于 06-12 11:20 ?780次閱讀
    服務(wù)器數(shù)據(jù)恢復(fù)—重裝<b class='flag-5'>系統(tǒng)</b>導(dǎo)致XFS<b class='flag-5'>文件系統(tǒng)</b>分區(qū)丟失的數(shù)據(jù)恢復(fù)案例

    服務(wù)器數(shù)據(jù)恢復(fù)—ocfs2文件系統(tǒng)被格式化為Ext4文件系統(tǒng)的數(shù)據(jù)恢復(fù)案例

    服務(wù)器存儲數(shù)據(jù)恢復(fù)環(huán)境&故障: 人為誤操作將Ext4文件系統(tǒng)誤裝入一臺服務(wù)器存儲上的Ocfs2文件系統(tǒng)數(shù)據(jù)卷上,導(dǎo)致原Ocfs2文件系統(tǒng)被格式化為Ext4文件系統(tǒng)
    的頭像 發(fā)表于 06-10 12:03 ?706次閱讀
    服務(wù)器數(shù)據(jù)恢復(fù)—ocfs2<b class='flag-5'>文件系統(tǒng)</b>被格式化為Ext4<b class='flag-5'>文件系統(tǒng)</b>的數(shù)據(jù)恢復(fù)案例

    EM-1000儲能網(wǎng)關(guān)如何批量部署應(yīng)用

    EM-1000實(shí)現(xiàn)了以Overlayfs為基礎(chǔ)的文件疊層系統(tǒng),分離了系統(tǒng)文件和用戶文件,其好處是
    的頭像 發(fā)表于 05-16 11:37 ?584次閱讀
    EM-1000儲能網(wǎng)關(guān)如何批量部署應(yīng)用

    Linux文件系統(tǒng)打包及鏡像制作,觸覺智能RK3562開發(fā)板演示

    本文介紹Linux開發(fā)板文件系統(tǒng)打包及鏡像制作的方法,演示Linux文件系統(tǒng)打包及鏡像制作,適用于想將配置好的系統(tǒng)環(huán)境打包成鏡像批量燒錄。觸
    的頭像 發(fā)表于 04-28 16:45 ?953次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>文件系統(tǒng)</b>打包及鏡像制作,觸覺智能RK3562開發(fā)板演示

    支持48位尋址!華為開源文件系統(tǒng)EROFS跨入大模型訓(xùn)練

    的要求。 ? 最近,開源文件系統(tǒng)EROFS在即將到來的Linux 6.15內(nèi)核周期中進(jìn)行擴(kuò)展,以處理更大規(guī)模的存儲系統(tǒng)。此次改進(jìn)旨在使EROFS更適配AI訓(xùn)練場景及其他大規(guī)模數(shù)據(jù)歸檔需求。 ? 在
    發(fā)表于 03-27 01:22 ?1093次閱讀

    如何正確選擇嵌入式文件系統(tǒng)?

    Linux嵌入式系統(tǒng)中,文件系統(tǒng)和緩存機(jī)制常導(dǎo)致數(shù)據(jù)存儲穩(wěn)定性問題。本文通過案例分析原因,對比不同文件系統(tǒng)特性,為開發(fā)者提供優(yōu)化建議,助力提升數(shù)據(jù)穩(wěn)定性和
    的頭像 發(fā)表于 03-17 11:35 ?1072次閱讀
    如何正確選擇嵌入式<b class='flag-5'>文件系統(tǒng)</b>?

    在stm32cubeprogrammer上燒錄時,取消勾選根文件系統(tǒng),燒錄后發(fā)現(xiàn)sd卡上根文件系統(tǒng)的分區(qū)沒有了,為什么?

    在修改了linux內(nèi)核后,我想只把bootfs燒錄到sd卡上,而不擦除根文件系統(tǒng)的分區(qū)。 我在stm32cubeprogrammer上燒錄時,取消勾選根文件系統(tǒng),燒錄后發(fā)現(xiàn)sd卡上根文件系統(tǒng)
    發(fā)表于 03-07 06:38

    NFS網(wǎng)絡(luò)文件系統(tǒng)深度解析

    NFS:Network File System 網(wǎng)絡(luò)文件系統(tǒng),基于內(nèi)核的文件系統(tǒng)。Sun 公司開發(fā),通過使用 NFS,用戶和程序可以像訪問本地文件一樣訪問遠(yuǎn)端系統(tǒng)上的
    的頭像 發(fā)表于 03-01 14:15 ?1387次閱讀