Rm (Unix)
rm,是一个基本的UNIX命令,其名称源自英文单词remove的缩写,用于删除文件系统中的文件、目录、设备文件、符号链接等对象。准确地说,rm移除的指向特定对象的引用。在文件系统中,这些特定的对象可能有多个引用(例如,两个不同的文件名可能指向相同的文件), 只有在一个对象不再有任何引用,并且没有任何程序还拥有这个文件的有效句柄的时候,这个文件才会被删除。 这一机制允许下列出现:某个程序可以创建一个文件,并立即将此文件从文件系统中移除,并将这个文件占用的空间作为临时空间使用。(因为在该程序退出甚至是崩溃的时候,这一文件占用的空间会被回收。) rm命令一般来说并不摧毁文件数据,因为其目的仅仅在于解除引用。即便文件已经解除所有的引用,在文件系统中,被释放的空间里可能还会有被删除文件的残留数据。在一些情况下这会带来安全问题,因此有时加强版的命令会在文件的最后一个链接断开之后抹除被删除文件的数据。此外,一些程序(例如:shred)可以提供数据抹除能力。 示例下列命令将名为"foo"的文件自目录中移除: % rm foo
一般而言,rm不产生输出信息,其只在错误发生的时候才报告错误信息。 如果加上参数 -v,则可以获得详细的文件移除的动作信息。 有时用户担心意外删除文件,特别是在使用通配符删除文件的时候。 这些情况下可以使用 -i参数,使rm在执行每个删除动作之前都提示用户确认。 % rm -i foo
remove foo? y
背景rm 一般在UNIX及其衍生操作系统中出现,而这些系统不提供已被删除文件的恢复机制(例如回收站)[1],因此用户常对rm命令进行一些封装以避免意外删除文件。 也有被称为undelete的实用工具。如果被删除文件原先占用的部分未被再度利用,这一工具将尝试恢复文件的索引以将这一被删除文件恢复。 命令参数rm命令接受的常见参数有:
利用C shell命令alias或是Bourne shell的功能,rm命令常常被“rm -i”命令覆盖,这样可以防止意外的文件删除操作。 如果用户还是想不通过确认而删除大量的文件,他们可以手动为命令追加“-f”参数,取消"-i"参数的效果(这是因为加上“-f”参数后,命令变为了“rm -i -f”,而后指定的参数有更高的优先级)。不过这个方法也可能使用户养成使用通配符等危险的习惯,而这一习惯还是会导致意外的文件删除。 rm -rf(其他的形式包括: rm -rf /, rm -rf *等)常常在描述UNIX灾难的笑话和轶事中出现[2]。 若在根目录由超级用户执行 rm -rf 命令,将会导致系统中所有已挂载可写入文件系统中所有内容的清除,直到系统自身因为丢失重要文件或目录而崩溃或其他致命系统事件,这一命令才会终止。 rm命令常常与xargs命令一起使用,这样就可以支持给定列表的文件批量删除: xargs rm < filelist
或者,也可以删除在当前目录下(包含子目录)的所有PNG图像文件: find . -name '*.png' -print0 | xargs -0 rm
权限一般而言,在大部分文件系统中,删除文件需要文件所在目录的写权限(首先为了进入该目录,还需要该目录的执行权限)。(注意:这里需要的是目录的执行权限,至于文件自身是否有写权限与删除操作成功与否无关。然而,除非使用-f参数,如果想要删除写保护文件,GNU rm将询问用户确认。) 使用 若在将要删除的目录中的某个文件设置了sticky bit,那么这个文件只能由其所有者删除。 文件系统根目录保护太阳微系统在2005首次发布的Solaris 10中,引入了" 用户确认系统管理员、设计人员、用户常通过创建别名或是使用函数的方法覆盖rm命令,试图避免意外删除文件: alias rm="rm -i"
rm () { /bin/rm -i "$@" ; }
这样处理使 一种折衷的方法允许用户只进行一次确认,鼓励适当使用通配符,更容易验证将要删除的文件列表,实现的参考代码如下: if [ -n "$PS1" ] ; then
rm ()
{
ls -FCsd "$@"
echo 'remove[ny]? ' | tr -d '\012' ; read
if [ "_$REPLY" = "_y" ]; then
/bin/rm -rf "$@"
else
echo '(cancelled)'
fi
}
fi
需要注意的是这一函数不该制成shell脚本,这样可能导致其在搜索路径中先于原始的rm命令。
其也不该在非交互的shell中使用,因为这一脚本可能会中断批处理任务。将这一定义封装在 也有一些第三方封装可以预防重要文件被意外删除,例如"safe-rm"。[4] 参见
参考资料
|