GoForum🌐 V2EX

nfs mv 的操作是原子的么? A 节点 move, B 节点要么完全可见,要么完全不可见?

weishao666 · 2026-03-24 18:34 · 0 次点赞 · 1 条回复

比如机器 A 、B 的/data 挂载了同一个 nfs 挂载点,A 机器/data 目录下有一个文件夹 a 下有 10000 个文件,我把/data/a 移动到/data/b ,对于机器 B 而言,如果节点 A 上已经看到 move 完成了,那么节点 B 上由于 nfs 异步延迟的存储,可能前几秒看不到这个移动的操作,过几秒之后可以看到/data/a 变成了/data/b ,那么存不存在一个中间状态,我能看到/data/b ,但是/data/b 下只有比如 2000 个文件

1 条回复
silverwzw · 2026-03-24 19:14
#1

我的理解是,nfs 的 rename 应该是原子的。因为 RFC 1813 (即 NFS v3 标准)的 3.3.14 节( Procedure 14: RENAME - Rename a File or Directory ) DESCRIPTION 部分是这么说的 “The operation is required to be atomic to the client.”

添加回复
你还需要 登录 后发表回复

登录后可发帖和回复

登录 注册
主题信息
作者: weishao666
发布: 2026-03-24
点赞: 0
回复: 0