今天在知乎上看到一篇十分有趣的問題:
如何評(píng)價(jià)微軟高級(jí)工程師癡迷于soft link這一linux常見概念?
雖然又是知名撕逼王曾某的撕逼帖,但是我還是想就題目中鏈接的問題簡(jiǎn)單地講講勇劣。
什么是鏈接嗦枢?
鏈接簡(jiǎn)單說實(shí)際上是一種文件共享的方式,是 POSIX 中的概念甲雅,主流文件系統(tǒng)都支持鏈接文件峰锁。
它是用來干什么的萎馅?
你可以將鏈接簡(jiǎn)單地理解為 Windows 中常見的快捷方式(或是 OS X 中的替身),Linux 中常用它來解決一些庫(kù)版本的問題虹蒋,通常也會(huì)將一些目錄層次較深的文件鏈接到一個(gè)更易訪問的目錄中糜芳。在這些用途上,我們通常會(huì)使用到軟鏈接(也稱符號(hào)鏈接)魄衅。
軟鏈接和硬鏈接的區(qū)別是峭竣?
下面我們進(jìn)入正題,來探討一下軟硬兩種鏈接到底有什么區(qū)別晃虫?
首先皆撩,從使用的角度講,兩者沒有任何區(qū)別哲银,都與正常的文件訪問方式一樣扛吞,支持讀寫,如果是可執(zhí)行文件的話也可以直接執(zhí)行荆责。
那區(qū)別在哪呢滥比?在底層的原理上。
為了解釋清楚做院,我們首先在自己的一個(gè)工作目錄下創(chuàng)建一個(gè)文件盲泛,然后對(duì)這個(gè)文件進(jìn)行鏈接的創(chuàng)建:
$ touch myfile && echo "This is a plain text file." > myfile
$ cat myfile
This is a plain text file.
現(xiàn)在我們創(chuàng)建了一個(gè)普通地不能再普通的文件了濒持。然后我們對(duì)它創(chuàng)建一個(gè)硬鏈接,并查看一下當(dāng)前目錄:
$ ln myfile hard
$ ls -li
25869085 -rw-r--r-- 2 unixzii staff 27 7 8 17:39 hard
25869085 -rw-r--r-- 2 unixzii staff 27 7 8 17:39 myfile
在 ls
結(jié)果的最左邊一列查乒,是文件的 inode
值弥喉,你可以簡(jiǎn)單把它想成 C 語(yǔ)言中的指針郁竟。它指向了物理硬盤的一個(gè)區(qū)塊玛迄,事實(shí)上文件系統(tǒng)會(huì)維護(hù)一個(gè)引用計(jì)數(shù),只要有文件指向這個(gè)區(qū)塊棚亩,它就不會(huì)從硬盤上消失蓖议。
你也看到了,這兩個(gè)文件就如同一個(gè)文件一樣讥蟆,inode
值相同勒虾,都指向同一個(gè)區(qū)塊。
然后我們修改一下剛才創(chuàng)建的 hard 鏈接文件:
$ echo "New line" >> hard
$ cat myfile
This is a plain text file.
New line
可以看到瘸彤,這兩個(gè)文件果真就是一個(gè)文件修然。
下面我們看看軟鏈接(也就是符號(hào)鏈接)和它有什么區(qū)別。
$ ln -s myfile soft
$ ls -li
25869085 -rw-r--r-- 2 unixzii staff 36 7 8 17:45 hard
25869085 -rw-r--r-- 2 unixzii staff 36 7 8 17:45 myfile
25869216 lrwxr-xr-x 1 unixzii staff 6 7 8 17:47 soft -> myfile
誒质况,你會(huì)發(fā)現(xiàn)愕宋,這個(gè)軟鏈接的 inode
竟然不一樣啊,并且它的文件屬性上也有一個(gè) l
的 flag结榄,這就說明它與之前我們創(chuàng)建的兩個(gè)文件根本不是一個(gè)類型中贝。
下面我們?cè)囍鴦h除 myfile 文件,然后分別輸出軟硬鏈接的文件內(nèi)容:
$ rm myfile
$ cat hard
This is a plain text file.
New line
$ cat soft
cat: soft: No such file or directory
之前的硬鏈接沒有絲毫地影響臼朗,因?yàn)樗?inode
所指向的區(qū)塊由于有一個(gè)硬鏈接在指向它邻寿,所以這個(gè)區(qū)塊仍然有效,并且可以訪問到视哑。
然而軟鏈接的 inode
所指向的內(nèi)容實(shí)際上是保存了一個(gè)絕對(duì)路徑绣否,當(dāng)用戶訪問這個(gè)文件時(shí),系統(tǒng)會(huì)自動(dòng)將其替換成其所指的文件路徑挡毅,然而這個(gè)文件已經(jīng)被刪除了蒜撮,所以自然就會(huì)顯示無(wú)法找到該文件了。
為驗(yàn)證這一猜想慷嗜,我們?cè)傧蜻@個(gè)軟鏈接寫點(diǎn)東西:
$ echo "Something" >> soft
$ ls
hard myfile soft
可以看到淀弹,剛才刪除的 myfile 文件竟然又出現(xiàn)了!這就說明庆械,當(dāng)我們寫入訪問軟鏈接時(shí)薇溃,系統(tǒng)自動(dòng)將其路徑替換為其所代表的絕對(duì)路徑,并直接訪問那個(gè)路徑了缭乘。
總結(jié)
到這里我們其實(shí)可以總結(jié)一下了:
- 硬鏈接: 與普通文件沒什么不同沐序,
inode
都指向同一個(gè)文件在硬盤中的區(qū)塊 - 軟鏈接: 保存了其代表的文件的絕對(duì)路徑,是另外一種文件,在硬盤上有獨(dú)立的區(qū)塊策幼,訪問時(shí)替換自身路徑邑时。