您好,登錄后才能下訂單哦!
本篇內容介紹了“linux硬鏈接和軟鏈接的區別”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
簡而言之:
軟鏈接相當于windows中的快捷方式
硬鏈接相當于一個災備系統,數據存放在兩處,與復制不同的是兩處之間存在同步機制,一處數據的改變會實時同步到另一處,另外一處數據如果被刪除了,不會影響到另一處的數據.
下面是詳細的介紹:
存在兩種不同類型的鏈接,軟鏈接和硬鏈接。修改其中一個,硬連接指向的是節點(inode),而軟連接指向的是路徑(path)
軟鏈接文件
軟鏈接又叫符號鏈接,這個文件包含了另一個文件的路徑名。可以是任意文件或目錄,可以鏈接不同文件系統的文件。和win下的快捷方式差不多。 鏈接文件甚至可以鏈接不存在的文件,這就產生一般稱之為"斷鏈"的問題(或曰“現象"),鏈接文件甚至可以循環鏈接自己。類似于編程語言中的遞歸。
命令格式:
代碼: ln [-s] source_path target_path 硬鏈接文件
info ln 命令告訴您,硬鏈接是已存在文件的另一個名字,硬連接的命令是:
代碼: ln -d existfile newfile //如果不加任何參數,默認情況下是硬鏈接.
硬鏈接文件
硬鏈接文件有兩個限制:
1、不允許給目錄創建硬鏈接;
2、只有在同一文件系統中的文件之間才能創建鏈接。
對硬鏈接文件進行讀寫和刪除操作時候,結果和軟鏈接相同。但如果我們刪除硬鏈接文件的源文件,硬鏈接文件仍然存在,而且保留了原有的內容。這時,系統就“忘記”了它曾經是硬鏈接文件。而把他當成一個普通文件。修改其中一個,與其連接的文件同時被修
改.
代碼:
$ cp /etc/httpd/conf/httpd.conf /usr/sam
$ ln httpd.conf httpd1.conf (硬鏈接)
$ ln -s httpd.conf httpd2.conf (軟鏈接)
第一條為硬鏈接,第二條為軟鏈接
代碼:
$ ls -li //查看一個文件或目錄的inode,要通過ls 命令的的 -i參數,inode值相同的文件,他們的關系是互為硬鏈接的關系
代碼:
總用量 80
1077669 -rw-r--r-- 2 sam adm 34890 10月 31 00:57 httpd1.conf (連接數變為2)
1077668 lrwxrwxrwx 1 sam adm 10 10月 31 00:58 httpd2.conf -> httpd.conf (類似于Win快捷方式)
1077669 -rw-r--r-- 2 sam adm 34890 10月 31 00:57 httpd.conf (連接數變為2)
可以看到,使用ls -li,軟連接只產生了10字節的快捷而已,硬連接卻實實在在的的拷貝。最前面的inode硬鏈接和源文件是一樣的
,而軟鏈接不一樣.對http1.conf進行編輯,可以發現httpd.conf也發生了一樣的變化.
代碼:
$ rm httpd.conf
現在刪除鏈接的源文件,來比較不同之處
代碼:
$ ls -l
總用量 44
drw-r--r-- 2 sam adm 4096 10月 30 20:14 file6
-rw-r--r-- 1 sam adm 34890 10月 31 00:57 httpd1.conf
lrwxrwxrwx 1 sam adm 10 10月 31 00:58 httpd2.conf -> httpd.conf
發現,httpd2.conf實際已經不存在了,是斷鏈,而httpd1.conf變也了普通文件.
詳細示例分析(截圖):
查看硬鏈接ln關聯的所有文件及路徑
ls -i myInfo.txt
3814056 myInfo.txt
find / -inum 3814056
/home/homer/me/myInfo.txt
/home/homer/me/.me/myInfo.txt_ln
/home/homer/bin/myInfo.txt
一 鏈接文件
鏈接有兩種方式,軟鏈接和硬鏈接。
1 軟鏈接文件
軟鏈接又叫符號鏈接,這個文件包含了另一個文件的路徑名。可以是任意文件或目錄,可以鏈接不同文件系統的文件。
鏈接文件甚至可以鏈接不存在的文件,這就產生一般稱之為"斷鏈"的問題(或曰“現象"),鏈接文件甚至可以循環鏈接自己。類似于編程語言中的遞歸。
用ln -s 命令可以生成一個軟連接,如下:
[root@linux236 test]# ln -s source_file softlink_file
在對符號文件進行讀或寫操作的時候,系統會自動把該操作轉換為對源文件的操作,但刪除鏈接文件時,系統僅僅刪除鏈接文件,而不刪除源文件本身。
2 硬鏈接文件
info ln 命令告訴您,硬鏈接是已存在文件的另一個名字(A "hard link" is another name for an existing file),這多少有些令人困惑。硬連接的命令是
ln -d existfile newfile
硬鏈接文件有兩個限制
1)、不允許給目錄創建硬鏈接;
2)、只有在同一文件系統中的文件之間才能創建鏈接。
對硬鏈接文件進行讀寫和刪除操作時候,結果和軟鏈接相同。但如果我們刪除硬鏈接文件的源文件,硬鏈接文件仍然存在,而且保留了愿有的內容。
這時,系統就“忘記”了它曾經是硬鏈接文件。而把他當成一個普通文件。
二 兩者之間的區別
硬連接指通過索引節點來進行的連接。在Linux的文件系統中,保存在磁盤分區中的文件不管是什么類型都給它分配一個編號,稱為索引節點號(Inode Index)。
在Linux中,多個文件名指向同一索引節點是存在的。一般這種連接就是硬連接。硬連接的作用是允許一個文件擁有多個有效路徑名,這樣用戶就可以建立硬連接到重要文件,以防止“誤刪”的功能。其原因如上所述,因為對應該目錄的索引節點有一個以上的連接。只刪除一個連接并不影響索引節點本身和其它的連接,只有當最后一個連接被刪除后,文件的數據塊及目錄的連接才會被釋放。也就是說,文件才會被真正刪除。
軟鏈接文件有點類似于Windows的快捷方式。它實際上是特殊文件的一種。在符號連接中,文件實際上是一個文本文件,其中包含的有另一文件的位置信息。
軟鏈接也有硬鏈接沒有的缺點,因為鏈接文件包含有原文件的路徑信息,所以當原文件從一個目錄下移到其他目錄中,再訪問鏈接文件,系統就找不到了;還有它要系統分配額外的空間用于建立新的索引節點和保存原文件的路徑。
而硬鏈接就沒有上面的缺陷,你想怎么移就怎么移
軟鏈接相當于windows中的快捷方式。硬鏈接相當于一個災備系統,數據存放在兩處,與復制不同的是兩處之間存在同步機制,一處數據的改變會實時同步到另一處,另外,一處數據如果被刪除了,不會影響到另一處的數據.
詳細的介紹:
硬連接指向的是節點(inode),是已存在文件的另一個名字,修改其中一個,與其連接的文件同時被修改;對硬鏈接文件進行讀寫和刪除操作時候,效果和軟鏈接相同。但如果我們刪除硬鏈接文件的源文件, 硬鏈接文件仍然存在,而且保留了原有的內容。這時,系統就“忘記”了它曾經是硬鏈接文件,而把他當成一個普通文件。 硬鏈接文件有兩個限制: 1、不允許給目錄創建硬鏈接; 2、只有在同一文件系統中的文件之間才能創建鏈接。
軟鏈接指向的是路徑,又叫符號鏈接,這個文件包含了另一個文件的路徑名可以是任意文件或目錄,還可以鏈接不同文件系統的文件,和win下的快捷方式差不多。軟鏈接文件甚至可以鏈接不存在的文件,這就產生一般稱之為"斷鏈"的問題(或曰“現象"),鏈接文件甚至可以循環鏈接自己,類似于編程語言中的遞歸。
示例:
ln exitfile newfile
ln -s exitfile newfile
這里的newfile為創建的鏈接名字,第一個沒有參數,默認是硬鏈接,第二個 -s 表示是軟鏈接。
ls -il 可以查看文件的inode號等屬性,例如:
[root@server tmp]# touch file
[root@server tmp]# ln file file1
[root@server tmp]# ln -s file file2
[root@server tmp]# ls -il
total 0
27127 -rw-r--r--. 2 root root 0 Nov 20 10:40 file
27127 -rw-r--r--. 2 root root 0 Nov 20 10:40 file1
27132 lrwxrwxrwx. 1 root root 4 Nov 20 10:40 file2 -> file
在 /tmp 目錄下,創建名為file的文件,先后創建硬鏈接file1,軟鏈接file2.觀察ls -il的輸出
file 和 file1 的inode是一樣的,所以可以說硬鏈接是指針指向同一個inode,系統并不為他重新分配inode。file2指向file,說明file2是軟鏈接,inode號也發生變化,
若刪除原始文件file,硬鏈接繼續使用,但軟鏈接就失效了。這點與win下的快捷方式類似。
這里需要強調的是,ls -l 命令輸出中的第3個字段內容,此為inode鏈接數,只要不為0,對于硬鏈接來說,文件就一直存在,不管你刪的是源文件還是之前生成的硬鏈接。
“linux硬鏈接和軟鏈接的區別”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。