您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關(guān)Linux文件執(zhí)行中的鎖定怪現(xiàn)象分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
linux下,一個可執(zhí)行文件exe1正在執(zhí)行中,rm –f可以將其刪除,mv可以將其移除,mv $other exe1也可以將其替換,但是cp $other exe1則顯示文件忙,求解。
這實際上并不是一個真正的問題,因為只要你的基礎知識扎實,這個問題顯然很簡單,原因只有一個,那就是linux文件基于引用計數(shù)?,F(xiàn)在問題是這些個命令如何來操作一個文件的引用計數(shù)。下面的討論都是基于獨占打開的模式。
如果一個文件已經(jīng)被打開,那么它的引用計數(shù)會增加1,如果調(diào)用了rm,實際上底層只是unlink了一下,也就是說將它的引用計數(shù)減少1,這樣雖然你在界面上(命令行或者GUI)看不到它了,但是它被打開時的計數(shù)還在,只有當它被關(guān)閉的時候,引用計數(shù)變?yōu)?,才徹底刪除它。
再說mv命令,它實際上只是一個源文件的rename而已,如果mv的目標本來就存在,那么在目標上執(zhí)行一個類似rm的效果,也就是unlink一下,結(jié)合引用計數(shù)的理論,目標文件如果已經(jīng)被打開,那么當關(guān)閉的時候?qū)⒉粡痛嬖?,如果本來就沒有被打開,那么mv的時候,目標直接被刪除,因為unlink之后,它的引用計數(shù)變成了0。
最后看一下cp命令,cp的話并不觸動源文件和目標文件元數(shù)據(jù)本身(時間戳除外),它只是打開源文件和目標文件,在源文件上執(zhí)行read,然后將結(jié)果write到目標文件,實質(zhì)上是一個IO操作,對于可執(zhí)行文件,是獨占打開的,并不允許寫入,因此會出錯。
這里就不再列出內(nèi)核源碼了,可以自行參考系統(tǒng)調(diào)用的實現(xiàn)而加深理解,不過最好別干巴巴的看,還是結(jié)合strace以及objdump比較好,要知道是怎么以及什么時候調(diào)用的,以及調(diào)用參數(shù)是什么,否則就和八股文沒區(qū)別了。那么這和我工作中的bug有什么關(guān)系呢?這個bug源于OpenVPN的日志記錄,并且配置了日志回滾,回滾配置文件關(guān)鍵字段如下:
size 4M
missingok
rotate 9
compress
delaycompress
create 644 xx xx
…
結(jié)果當日志回滾成了vpn.log.1之后,這個vpn.log.1依然繼續(xù)被寫入。這個原因正是rename造成的。在logrotate的man頁面中,有一個copytruncate配置,其含義就是不進行rename,而只是copy,然后將原來的文件truncate,加入這個就可以了。
千萬不要小看這些很簡單的命令,真正理解的人并不多,即使真正的理解,出現(xiàn)問題,能真正對應到原理也不多,很簡單的東西如果能徹底做到透徹的理解并且活用,再往深入學習才是有意義的。
關(guān)于“Linux文件執(zhí)行中的鎖定怪現(xiàn)象分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。