POSIX对rename行为的定义如下(http://www.opengroup.org/onlinepubs/009695399/functions/rename.html):

  1. 将一个文件重命名为一个目录,或将一个目录重命名为一个文件将会失败。
  2. 将旧文件重命名为一个已经存在的新文件将会成功,原本存在的新文件会先被删除。
  3. 将旧目录重命名为一个已经存在的、且非空的新目录会失败。
  4. 将旧目录重命名为一个已经存在的、空的新目录会成功,原本存在的新目录会先被删除。
  5. 新路径以旧路径作为前缀会失败。
  6. 新路径包含不存在的父目录会失败,(如将/a/b重命名为/c/d而c不存在时,会失败)。

因为2、4条的缘故,rename要实现原子操作有些困难,因而部分文件系统放弃了对rename POSIX语义的兼容,如WinNT使用的NTFS,在重命令的新路径已经存在时统一会失败;

目前HDFS也放弃2、4;

05-11 14:37