通过 NFS 导出的不同环回安装卷被客户端视为 1

通过 NFS 导出的不同环回安装卷被客户端视为 1

我有一个相当奇怪的问题。我正在运行3.2.0-58-generic #88-Ubuntu(Ubuntu 12.04)并且我已经安装了以下环回设备:

cat /proc/mounts | grep loop
    /dev/loop0 /work/kernel/AEL/fpga-filesystem ext4 rw,relatime,user_xattr,barrier=1,data=ordered 0 0
    /dev/loop1 /work/kernel/AEL/model-filesystem ext4 rw,relatime,user_xattr,barrier=1,data=ordered 0 0

sudo losetup -a
/dev/loop0: [fc02]:4990567 (/work/kernel/AEL/openembed-fpga.img), offset 54525952
/dev/loop1: [fc02]:4990564 (/work/kernel/AEL/vexpress64-openembedded_minimal-armv8-gcc-4.8_20140222-611.img), offset 54525952

这两个 .img 文件是完全独立的文件,而不是符号链接:

ls -li /work/kernel/AEL/
      2 drwxr-xr-x 21 root     root           4096 Mar 26 20:14 fpga-filesystem
      2 drwxr-xr-x 21 root     root           4096 Mar 26 20:05 model-filesystem
4990567 -rw-r-----  1 nikbor01 nikbor01 3221225472 Mar 27 09:47 openembed-fpga.img
4990564 -rw-r-----  1 nikbor01 nikbor01 3221225472 Mar 26 20:06 vexpress64-openembedded_minimal-armv8-gcc-4.8_20140222-611.img

两个目录具有相同 INODE 编号的原因是图像相同(具有相同的内容),但显然安装在不同的循环设备下。

最后,我导出通过 nfs 挂载图像的 2 个目录:

/work/kernel/AEL/fpga-filesystem *(rw,sync,no_subtree_check,no_root_squash,insecure)
/work/kernel/AEL/model-filesystem *(rw,sync,crossmnt,no_subtree_check,no_root_squash,insecure)

现在是一切的顶峰 - 当我在 client1 上安装 fpga-filesystem 并在 client2 上安装 model-filesystem 时,它们都会看到相同的文件系统(例如 fpga-filesystem 下的文件系统)。

这是 client1 上的挂载:

10.1.209.36:/work/kernel/AEL/fpga-filesystem / nfs rw,relatime,vers=3,rsize=4096,wsize=4096,namlen=255,hard,nolock,proto=tcp,timeo=600,retrans=2,sec=sys,mountaddr=10.1.209.36,mountvers=3,mountproto=tcp,local_lock=all,addr=10.1.209.36 0 0

在 client2 上:

10.1.209.36:/work/kernel/AEL/model-filesystem / nfs rw,relatime,vers=3,rsize=4096,wsize=4096,namlen=255,hard,nolock,proto=tcp,timeo=600,retrans=2,sec=sys,mountaddr=10.1.209.36,mountvers=3,mountproto=tcp,local_lock=all,addr=10.1.209.36 0 0

但是,当我ls /在两个客户端上执行此操作时,我只看到 fpga-filesystem 目录的内容,这完全没有意义。我有什么想法可以调试这个问题。

相关内容