軟鏈接和硬鏈接——Linux中的文件共用

来源:https://www.cnblogs.com/sea-progress/archive/2020/02/04/12259417.html
-Advertisement-
Play Games

硬鏈接(Hard Link)和軟鏈接也稱為符號鏈接(Symbolic Link)的目的是為瞭解決文件的共用使用問題。要闡明其原理,必須先理解Linux的文件存儲方式。 索引結點 Linux是一個UNIX類操作系統,所有類型的UNIX文件都是由操作系統通過索引節點來管理的。 索引節點是一個控制結構,包 ...


硬鏈接(Hard Link)和軟鏈接也稱為符號鏈接(Symbolic Link)的目的是為瞭解決文件的共用使用問題。要闡明其原理,必須先理解Linux的文件存儲方式。

索引結點

Linux是一個UNIX類操作系統,所有類型的UNIX文件都是由操作系統通過索引節點來管理的。


索引節點是一個控制結構,包含操作系統所需的關於某個文件的關鍵信息。多個文件名能與一個索引節點相關聯,但一個活躍的索引節點只能與一個文件相關聯,且每個文件只能由一個索引節點來控制。文件的屬性、訪問許可權和其他控制信息都保存在索引節點中。此處以Linux中ext2的索引結點示例。

Ext2文件系統的每一個文件和目錄都對應一個索引結點,每一個數據塊組中的索引結點都保存在索引結點表中。

ext2的索引結點的一些主要欄位:

Mode:包含次索引結點描述的是什麼(比如描述文件、目錄、符號鏈接、塊設備、字元設備以及FIFO結構等)以及用戶擁有的許可權

Owner information:文件或目錄所有者的用戶和組標識符,這使得文件系統可以正確地授權某種存取操作

Size:文件大小

Timestamps:建立時間和最後修改時間

Datablocks:指向存儲此索引結點描述的文件數據塊的指針。直接指針指向存儲數據的物理數據塊,間接指針、兩級指針和三級指針指向不同級別的指針塊或數據。


  具體的索引節點結構會因為UNIX實現的不同而發生變化,再舉一個FreeBSD的索引節點結構:

當訪問一個文件時,通過文件名在目錄表中查找到其索引節點號,通過索引節點號查索引節點表得到其索引節點,通過索引節點得到文件數據所在的位置。

索引結點也會消耗硬碟空間,所以硬碟格式化的時候,操作系統自動將硬碟分成兩個區域。一個是數據區,存放文件數據(data block);另一個是索引結點區(inode table),存放索引結點所包含的信息。

每個索引結點的大小,一般是128位元組或256位元組。索引結點的總數,在格式化時就給定,一般是每1KB或每2KB就設置一個索引結點。

Linux中的相關命令:

查看每個硬碟分區的索引結點總數和已經使用的數量,可使用df命令:df -

查看每個索引結點節點的大小,可以用如下命令:sudo dumpe2fs -h /dev/hda | grep “Inode size”

使用ls –l命令會顯示出在大部分信息. ls –i option顯示文件的索引號.

而stat命令則可以列出索引節點中的幾乎所有信息.

文件系統第一次被創建時, 會為每一個文件系統創建若幹數量的索引節點。該數目是文件系統所能容納的最大文件數。只要不重新初始化文件系統, 就不能改變這個數目, 否則會損壞該文件系統上所有的數據。當文件系統中有很多很多小文件時文件系統會可能將索引節點全部用光。

一個文件系統維護了一個索引節點的數組,每個文件或目錄都與索引節點數組中的唯一一個元素對應。系統給每個索引節點分配了一個號碼,也就是該節點在數組中的索引號,稱為索引節點號。操作系統用索引結點號碼來識別不同的文件。

錶面上,用戶通過文件名,打開文件。實際上,系統內部這個過程分成三步:首先,系統找到這個文件名對應的索引結點號碼;其次,通過索引結點號碼,獲取索引結點信息;最後,根據索引結點信息,找到文件數據所在的block,讀出數據。

使用ls -i命令,可以看到文件名對應的inode號碼:ls -i example.txt

由於索引結點與文件名分離,這種機制導致了一些Unix/Linux系統特有的操作

1. 若出現文件名包含特殊字元,無法正常刪除的情況。這時,可以通過直接刪除索引結點來刪除文件。

2. 移動文件或重命名文件,只是改變文件名,不影響索引結點號碼。

3. 打開一個文件以後,系統就以索引結點號碼來識別這個文件,不再考慮文件名。因此,通常來說,系統無法從索引結點號碼得知文件名。

  第3點使得軟體更新變得簡單,可以在不關閉軟體的情況下進行更新,不需要重啟。更新的時候,新版文件以同樣的文件名,生成一個新的索引結點,不會影響到運行中的文件。等到下一次運行這個軟體的時候,文件名就自動指向新版文件,舊版文件的索引結點則被回收。

硬鏈接和軟連接


基於索引結點共用:硬鏈接(hard link)

文件索引節點中設有一個鏈接計數欄位inode link count,用來表示連接到本索引結點上的用戶目錄項的數目

用戶A創建一個新文件時,inode link count;

用戶B要共用該文件,B的目錄中增加一個目錄項,並填上新的文件名和指向該共用文件的索引結點的指針,inode link count;

缺點:文件主無法刪除被他人共用的文件。

•在系統中占用的空間與源文件相同,但在系統中引用的是相同的對象(不是拷貝)

•在操作系統層解析

•圖標和創建快捷方式的圖標不同

•移除源文件不會影響硬鏈接

•移除硬鏈接不會影響源文件

•如果源文件被刪除,它的內容依然通過硬鏈接存在

•硬鏈接文件的任何更改都會影響到源文件

$ln a b    # b是a所指文件的硬鏈接

硬鏈接實際上是為原文件建立一個別名,鏈接文件和原文件實際上是同一個文件。可以通過ls -i來查看。兩個文件的inode號是同一個,說明它們是同一個文件。它只是在文件原來的inode link count域再增加1而已,也因此硬鏈接是不可以跨文件系統的。硬鏈接刪除的時候,系統調用會檢查inode link count的數值,如果它大於等於1,那麼inode不會被回收,因此文件的內容不會被刪除。目錄不能進行硬連接。目錄硬連接引用計數,如果形成環,刪除的時候會產生dangling dir。

 

基於文件路徑共用:符號鏈接(symbolic link)&軟連接(junction link or soft link)

為了能使B共用A的一個文件,系統為B建立一個類型為link的新文件,將該文件放在B的目錄下,在新文件中只包含了目標文件的路徑名,當B讀該link類型的文件時,將被OS截獲,並根據新文件中的路徑名去讀目標文件。這種實現文件共用的方式成為符號鏈接。

在這種方式下,文件主刪除被他人共用的文件後,其他用戶再去訪問該共用文件,會因找不到文件而失敗,再將該符號鏈刪除不會造成任何影響

缺點:其他用戶訪問共用我共用文件時,必鬚根據路徑中的分量名逐級檢索目錄,加大了訪問文件的開銷;儘管Link類型文件很簡單,但任需為它配置一個索引結點,並分配一個盤塊來存放目標文件的路徑名,這樣也增加了系統的開銷。

•創建鏈接後的圖標和快捷方式很像

•在系統中不占用空間

•在文件系統中不是一個單獨的文件

•在操作系統層解析

•如果源文件被刪除了,鏈接就沒用了

•移除源文件不會影響符號鏈接

•移除鏈接文件也不會影響源文件

$ ln –s a b    #為a創建一個符號鏈接b

rm b:a不受影響

rm a:a不存在,b能被控制但無法訪問

軟鏈接實質是新建立一個inode,產生一個新的文件,但這個文件的作用就是專門指向某個文件的,刪除這個軟鏈接文件,原來的實體原文件還是存在的,保持不變。但要是刪除原來的文件,則相應的軟鏈接不可用(cat那個軟鏈接文件,則提示“沒有該文件或目錄”)。符號鏈接可以跨文件系統,可以跨磁碟分區,符號鏈接的文件類型位是l。

比較

硬鏈接

1.只允許文件鏈接,不允許目錄鏈接;

2.只能在同一個文件系統範圍內進行,不允許跨文件系統。

3.刪除文件時,如果還有其他鏈接鏈至該文件,則該文件不能被刪除。

軟鏈接

1.訪問速度相對較慢,但適用範圍和靈活性更大。

2.允許目錄鏈接,允許在不同的文件系統間進行鏈接,這兩個文件系統可以在同一個電腦上,也可以在不同的電腦上。

3.被鏈接文件的刪除和符號鏈接的刪除是完全獨立的

 

資料出處

1. 操作系統第八版

2. 操作系統原理、設計及應用。高等教育出版社
3. 電子科技大學電腦學院蒲曉蓉老師操作系統課件
4. 電子科技大學電腦學院薛瑞尼老師操作系統課件


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 這是在ASP.NET Core 3.X中使用Serilog.AspNetCore系列文章的第四篇文章:。 1. "第1部分 使用Serilog RequestLogging減少日誌詳細程度" 2. "第2部分 使用Serilog記錄所選的終結點屬性" 3. "第3部分 使用Serilog.AspN ...
  • 實例2.1 通過控制台實現對Excel的自動化處理 書本第32頁 註:添加兩個引用: 第一個:程式集—框架—“System.Windows.Forms 4.0.0.0”第二個:程式集—擴展—“Microsoft.Office.Interop.Excel 14.0.0.0” 程式清單2.1通過控制台程 ...
  • WPF提供了許多封裝項的集合的控制項,本章介紹簡單的ListBox和ComboBox控制項,後續哈會介紹更特殊的控制項,如ListView、TreeView和ToolBar控制項。所有這些控制項都繼承自ItemsControl類(ItemsControl類本身又繼承自Control類)。 ItemsContr ...
  • 微信公眾號: "Dotnet9" ,網站: "Dotnet9" ,問題或建議: "請網站留言" , 如果對您有所幫助: "歡迎贊賞" 。 少量代碼設計一個登錄界面 .NET CORE(C ) WPF開發 閱讀導航 1. 本文背景 2. 代碼實現 3. 本文參考 4. 源碼 1. 本文背景 繼續 Ma ...
  • 內容控制項不僅包括基本控制項,如標簽、按鈕以及工具提示;它們還包含特殊容器,這些容器可用於構造用戶界面中比較大的部分區域。 首先介紹ScrollViewer控制項,該控制項直接繼承自ContentControl類,提供了虛擬界面,允許用戶圍繞更大的元素滾動。與所有內容控制項一樣,ScrollViewer只能包 ...
  • 在Sublime Text3安裝目錄下新建一個文件 sublime_addright.inf 文件內容: [Version] Signature="$Windows NT$" [DefaultInstall] AddReg=SublimeText3 [SublimeText3] hkcr,"*\\s ...
  • " 返回《C 併發編程》" "1. 初始化共用資源" "2. Rx延遲求值" "3. 非同步數據綁定" "4. 非同步構造" "5. 非同步屬性" 1. 初始化共用資源 不管同時有多少線程調用 ,這個工廠委托只會運行一次,並且所有線程都等待同一個實例。 + 實例在創建後會被緩存起來,以後所有對 Value ...
  • 根據磁碟IO告警,找到占用磁碟IO (util)讀寫很高的進程。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...