當(dāng)前位置:首頁(yè) > 公眾號(hào)精選 > Linux閱碼場(chǎng)
[導(dǎo)讀]OverlayFS,顧名思義是一種堆疊文件系統(tǒng),可以將多個(gè)目錄的內(nèi)容疊加到另一個(gè)目錄上。OverlayFS并不直接涉及磁盤(pán)空間結(jié)構(gòu),看起來(lái)像是將多個(gè)目錄的文件按照規(guī)則合并到同一個(gè)目錄。且對(duì)多個(gè)源目錄具體使用文件系統(tǒng)類型沒(méi)有要求,即使各個(gè)源目錄的文件系統(tǒng)類型不同也不影響使用。一、掛...

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




一、掛載OverlayFS





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


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


上面的命令可以將"lowerdir"和"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的多層目錄使用":"分隔開(kāi),其中層級(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中來(lái)自u(píng)pperdir的數(shù)據(jù)時(shí),數(shù)據(jù)將直接寫(xiě)入upperdir中原來(lái)目錄中,刪除文件也同理。? 當(dāng)用戶修改mergedir中來(lái)自lowerdir的數(shù)據(jù)時(shí),lowerdir中內(nèi)容均不會(huì)發(fā)生任何改變。因?yàn)閘owerdir是只讀的,用戶想修改來(lái)自lowerdir數(shù)據(jù)時(shí),overlayfs會(huì)首先拷貝一份lowerdir中文件副本到upperdir中(這也被稱作OverlayFS的copy-up特性)。后續(xù)修改或刪除將會(huì)在upperdir下的副本中進(jìn)行,lowerdir中原文件將會(huì)被隱藏。? 如果某一個(gè)目錄單純來(lái)自lowerdir或者lowerdir和upperdir合并,默認(rèn)無(wú)法進(jìn)行rename系統(tǒng)調(diào)用。但是可以通過(guò)mv重命名。如果要支持rename,需要CONFIG_OVERLAY_FS_REDIRECT_DIR。
一般lowerdir為只讀文件系統(tǒng),upperdir為可寫(xiě)文件系統(tǒng),這形成了一個(gè)有趣的機(jī)制,似乎我們可以修改lowerdir下的文件或目錄,lowerdir看上去變成了一個(gè)可讀寫(xiě)的文件系統(tǒng)。




二、刪除文件和目錄






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







可以看到刪除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è)空的目錄。







四、rename目錄





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


1. 返回EXDEV錯(cuò)誤碼:rename系統(tǒng)調(diào)用試圖穿過(guò)文件系統(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)打開(kāi)。


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


remount前:






remount后:






重啟:






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




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




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




六、小結(jié)






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














本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉