Re: 硬連結的用途 - Linux

Odelette avatar
By Odelette
at 2020-05-27T19:44

Table of Contents

※ 引述《HILL33LOVE (就是愛希爾)》之銘言:
: 最近看軟連結跟硬連結的比較,有整理一下筆記資訊,對於硬連結的觀念是都使用同一個
: inode,省硬碟空間等等,但是對於”實務”上還是不是很了解大家平常都使用在那邊?
: 再請大家給點指教,謝謝

我自己在實務上做過的, 是讓同一個可執行檔具有多種"操作模式".
這也是系統上常看見的"實務應用". 例如用以下指令列出 /bin/
下面 link count 大於 1 的所有檔案:

$ find /bin/ -type f -links +1 -exec stat -c "%h %i %n" '{}' \; | sort

2 7340502 /bin/gunzip
2 7340502 /bin/uncompress
(...)
3 7340137 /bin/bunzip2
3 7340137 /bin/bzcat
3 7340137 /bin/bzip2

以 bunzip2 為例好了, 如果我要它解壓縮並送到 stdout 的話, 會做:

$ bunzip2 -c 某檔.bz2

但是, 如果以 bzcat 叫它的話, 它會直接進入 "-c" 的操作模式:

$ zcat 某檔.bz2

兩者結果是一樣的. 寫程式用過一陣子, 後來不知怎樣就不這麼玩了...

順便提一下 hard link 的基本觀念, 有問題請大家幫我訂正

所謂"檔案", 是個資料結構, 它唯一的 id 是 inode number,
而非檔名, 因為同一個"檔案"可以有很多檔名, 而且沒有先後之分!

所以, 想像中, "檔案", 比較是 inode, 而不是 "檔名".

如上, inode 7340137 指向一個可執行檔, 並具有三個平起平坐的檔名:
/bin/bunzip2, /bin/bzcat, /bin/bzip2 (這三個名子完全"等價"!)

hard link 的另一個用途是, 例如, 讓它用 /bin/bzip2 跟 /usr/bin/bzip2
都找得到. 但是我的 Debian 上的 /bin/ 現在是 /usr/bin/ 的 symbolic link...

另外, hard link 引申出一個 admin 必須小心的觀念, 例如

$ rm <一個檔案>

其實並不"消滅"<一個檔案>, 而是 unlink(2) <一個檔案>!

那個名字被 unlinked 的"檔案" 其實還在
只要它的 link-count 非 0 或被 opened
而有個 file descriptor.
rm(1) 所消滅的是名字, 不是檔案

假設 admin 發現 /bin/sh "不乖", 於是找了新的版本,
他 # rm /bin/sh, # cp <新版> /bin/ 然後以為做完了.
那就麻煩了.... 因為舊的可能還存在:

1. 它還有 hard links
2. 它還被 opened (在 /proc/<pid>/fd/ 下找得到)

要徹底"消滅"這個 inode, 必須消滅以上兩點, 它才官方不存在


--
Tags: Linux

All Comments

Ethan avatar
By Ethan
at 2020-05-30T22:34
其實早期 GNU gzip 本身內建就支援一個單一程式檔案
Elizabeth avatar
By Elizabeth
at 2020-06-04T02:02
具備壓縮解壓縮等功能,所以 gzip,gunzip本身都是
hard link, 程式執行期會依據自己被執行程式名稱決定
Rosalind avatar
By Rosalind
at 2020-06-04T13:47
到底是要壓縮或是解壓縮。不過晚期 gzip 記得似乎已經
改掉這個了,gunzip 本身提供 script 等於呼叫 gzip -dc
Charlotte avatar
By Charlotte
at 2020-06-09T00:32
不過我不確定各家 linux 發行版本是否有異動,得再確認
Hedwig avatar
By Hedwig
at 2020-06-12T21:19
長知識了,謝謝原PO和樓上的解說
Christine avatar
By Christine
at 2020-06-13T11:01
這用 symlink 符號連結也可以,不一定要用硬連結
Una avatar
By Una
at 2020-06-14T05:51
至於這種用 argv[0] 來判斷動作的,還有 busybox 和
ssh-argv0 二個比較常見。
Andrew avatar
By Andrew
at 2020-06-15T09:04
用 argv[0] 判斷有缺點,比方你要真的複製得到一個真實
的 gzip 解壓縮工具,名稱只能夠用 gunzip 這樣,無法
改名成為 abc 等於原本解壓縮功能,有好有壞。所以系統
上很多戲法可以玩
Skylar Davis avatar
By Skylar Davis
at 2020-06-20T05:48
樓上有一招是 bash 的 exec -a ls /bin/busybox
Una avatar
By Una
at 2020-06-22T03:30
的確可以。題外話 lvm 目前大多 linux 系統其下工具
Olive avatar
By Olive
at 2020-06-23T10:18
應該大多都是用 symlink 然後連結到 lvm 主程式
Liam avatar
By Liam
at 2020-06-26T01:00
原來
Liam avatar
By Liam
at 2020-06-28T01:08
感謝分享

菜鳥想問PVE(proxmox) vm的remote access

Vanessa avatar
By Vanessa
at 2020-05-27T17:07
如題,現在想法是在一個node底下,每個人建一台vm給予連線(ssh)進來作業。 目前只有一組固定IP給node使用,後面的vm都是dhcp取得IP。 有個問題是說因每次vm取得的IP不固定,對方想遠端的話都要先知道該vm的IP才能連。 想問有沒有什麼辦法可以解決呢? 另外相同的硬體配置下,RAM/D ...

有在linux能寫巨集的按鍵精靈嗎?

Oscar avatar
By Oscar
at 2020-05-25T13:09
用windows 玩遊戲時我能用icue 的巨集輔助我做重複性的動作,在popos 就沒有這種軟體 了,google 找到的都只有最基本的按鍵組合功能,完全不能寫巨集 各位有推薦的軟體嗎?最好是有GUI的 -- 男孩子就應該喜歡剛陽的東西 例如男孩子 - ...

puppy安裝中文輸入法問題

Jacob avatar
By Jacob
at 2020-05-24T13:53
小弟是linux極新手 只是想在老筆電上跑linux http://electronmania.blogspot.com/2017/07/puppy-linux.html 用了這邊的32 位元 xenialpup 7.5 內建gcin,但常常ctrl+space呼叫不出來 打開text editor後若有成 ...

new WSL2 and new Docker at win10

Yuri avatar
By Yuri
at 2020-05-23T19:31
https://is.gd/JjgLXs 首先win10 要是2004以上 19041build以上 請去windows update 更新win10 2004 安裝有linux kernel的WSL2 https://docs.microsoft.com/en-us/windows/wsl/inst ...

grep 指令請益

Leila avatar
By Leila
at 2020-05-22T12:28
各位好,最近才開始學習在MAC使用GCC Mac從G++4.2.1更新到G++ 4.9.4編譯CPP檔案,發生以下的warnings, /var/folders/z8/01n_7c6s4pbchqppl8cvbnk00000gn/T//ccwgMHWc.s:4:11: warning: section ...