我意外地将整个磁盘 rsynced(带有符号链接)/
到了另一个磁盘。
我以普通用户身份运行 rsync。
意识到自己的错误后,我想清理备份。它删除了所有文件,除了(备份的)文件BACKUPFOLDER/dev/fd
已经很晚了,我很不耐烦,所以我sudo rm -rf *
进入了 BACKUPFOLDER,然后就把它们除掉了。
现在我开始思考:为什么我不能删除这些文件描述符备份(它们的所有者是我的用户名),并且我在sudo rm -rf
该备份上运行是否会损坏任何东西?
我意外地将整个磁盘 rsynced(带有符号链接)/
到了另一个磁盘。
我以普通用户身份运行 rsync。
意识到自己的错误后,我想清理备份。它删除了所有文件,除了(备份的)文件BACKUPFOLDER/dev/fd
已经很晚了,我很不耐烦,所以我sudo rm -rf *
进入了 BACKUPFOLDER,然后就把它们除掉了。
现在我开始思考:为什么我不能删除这些文件描述符备份(它们的所有者是我的用户名),并且我在sudo rm -rf
该备份上运行是否会损坏任何东西?
在基于 Linux 的操作系统上,
/dev/fd
是指向 的符号链接/proc/self/fd
,是/proc/self
指向 的符号链接/proc/$pid
,是其上$pid
执行 的进程的 idreadlink()
,并且/proc/$pid/fd
是一个虚拟的只读目录,其权限使得没有人对它具有写权限。因此,如果您将其
rsync
复制/dev/fd
为副本/proc/$pid/fd
(而不是符号链接的副本)并保留其中的权限,那么您最终会得到一个dr-x------ your-user your-group
目录,并且rm
无法删除其中的文件,因为它没有修改目录的权限。由于您拥有该目录,因此您应该能够更改这些权限,或者更一般地,
chmod -R u+rwx BACKUPFOLDER
如果您以自己的身份执行了该备份,那么rm -rf
就可以保证成功。无论如何,
sudo rm -rf BACKUPFOLDER
或sudo rm -rf BACKUPFOLDER/dev
(sudo rm -rf BACKUPFOLDER/*
会扩展为)或sudo rm -rf BACKUPFOLDER/dev/fd
不会对操作系统的其余部分造成任何损害rsync
。即使在那里创建了指向系统文件或目录的符号链接,rm
也会删除那里的符号链接,而不会按照指向目录的符号链接来删除其中的文件。并且无论如何甚至root
无法删除/proc/$pid/fd/$n
文件,因为这些是虚拟文件,会暴露内核不允许您删除的内部 Linux 内核信息。符号
/dev/fd
链接可以在当前版本的基于 Linux 的系统中被删除,/dev
它不是像在旧版本的 Linux 中那样的虚拟文件系统,而是由用户空间程序(udev/systemd)根据内核提供的信息自动填充的内容,但同样,只有当符号链接是指向 的符号链接(或指向 的符号链接或指向 的目录,其中包含指向 的符号链接)时rm -rf BACKUPFOLDER/dev/fd
才能删除它,而它们没有理由在这里。/dev/fd
BACKUPFOLDER/dev
/dev
BACKUPFOLDER
/
dev
/dev
关于你的几点说明
sudo rm -rf *
:*
被扩展(由 shell 而不是rm
)到其中的非隐藏文件列表,因此它不会删除隐藏文件。如果使用zsh
,则可以使用*(D)
而不是*
来删除隐藏文件。如果其中有以 开头的文件或目录
-
,则 的扩展*
可能包含 会将其视为选项的参数rm
。通常,在使用 globs 或至少 globs 的扩展不能保证不包含以 开头的元素-
(或+
对于某些命令)时,您需要使用--
选项分隔符:尽管你也可以这样做:
最好的办法是在这里做,
sudo rm -rf BACKUPFOLDER
这样可以避免这两个问题。