作者cuello (cuello)
看板Linux
标题Re: 硬连结的用途
时间Wed May 27 19:44:00 2020
※ 引述《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, 必须消灭以上两点, 它才官方不存在
--
※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 61.230.9.35 (台湾)
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/Linux/M.1590579842.A.656.html
1F:→ kenduest: 其实早期 GNU gzip 本身内建就支援一个单一程式档案 05/27 20:50
2F:→ kenduest: 具备压缩解压缩等功能,所以 gzip,gunzip本身都是 05/27 20:51
3F:→ kenduest: hard link, 程式执行期会依据自己被执行程式名称决定 05/27 20:51
4F:→ kenduest: 到底是要压缩或是解压缩。不过晚期 gzip 记得似乎已经 05/27 20:52
5F:→ kenduest: 改掉这个了,gunzip 本身提供 script 等於呼叫 gzip -dc 05/27 20:52
6F:→ kenduest: 不过我不确定各家 linux 发行版本是否有异动,得再确认 05/27 20:53
7F:推 Typebrook: 长知识了,谢谢原PO和楼上的解说 05/28 11:38
8F:推 Gold740716: 这用 symlink 符号连结也可以,不一定要用硬连结 05/28 15:17
9F:→ Gold740716: 至於这种用 argv[0] 来判断动作的,还有 busybox 和 05/28 15:18
10F:→ Gold740716: ssh-argv0 二个比较常见。 05/28 15:18
11F:→ kenduest: 用 argv[0] 判断有缺点,比方你要真的复制得到一个真实 05/28 15:37
12F:→ kenduest: 的 gzip 解压缩工具,名称只能够用 gunzip 这样,无法 05/28 15:37
13F:→ kenduest: 改名成为 abc 等於原本解压缩功能,有好有坏。所以系统 05/28 15:37
14F:→ kenduest: 上很多戏法可以玩 05/28 15:37
15F:推 Gold740716: 楼上有一招是 bash 的 exec -a ls /bin/busybox 05/28 19:14
16F:→ kenduest: 的确可以。题外话 lvm 目前大多 linux 系统其下工具 05/28 22:55
17F:→ kenduest: 应该大多都是用 symlink 然後连结到 lvm 主程式 05/28 22:56
18F:→ Gold740716: 原来 05/28 23:34
19F:推 lecheck: 感谢分享 05/30 10:33