我正在使用 NFS 来测试一些客户端选项。
在进行“选项”之前,我只是测试了从几个客户端到给定服务器的“默认”连接,因此稍后我将能够比较选项行为与默认行为。
但我观察到,即使客户端都基于ubuntu:20.04
相同版本且安装了相同版本,它们的行为也会有所不同nfs-common
。
设置如下:
服务器
Ubuntu 20.40 在桥接虚拟机中暴露 IP 192.168.3.81。服务器是 ubuntu 20.04 的默认软件包。
这些是已安装的 NFS 包:
xavi@iridio:~$ apt list --installed | grep nfs
WARNING: apt does not have a stable CLI interface. Use with caution in scripts.
libnfsidmap2/focal,now 0.25-5.1ubuntu1 amd64 [installed,automatic]
nfs-common/focal-updates,focal-security,now 1:1.3.4-2.5ubuntu3.3 amd64 [installed,automatic]
nfs-kernel-server/focal-updates,focal-security,now 1:1.3.4-2.5ubuntu3.3 amd64 [installed]
xavi@iridio:~$
这是导出文件:
xavi@iridio:~$ cat /etc/exports
/files/repos/sharedfolder *(rw,sync,no_subtree_check,no_root_squash,insecure)
xavi@iridio:~$
客户 # 1 (虚拟盒)
可以将 VirtualBox 上的同一台服务器机器作为其自身的客户端进行测试。安装时,它实际上使用协议 4.2:
xavi@iridio:~$ sudo mount -vvvv 192.168.3.81:/files/repos/sharedfolder iridio/
mount.nfs: timeout set for Tue May 4 10:41:51 2021
mount.nfs: trying text-based options 'vers=4.2,addr=192.168.3.81,clientaddr=192.168.3.81'
xavi@iridio:~$ echo $?
0
xavi@iridio:~$
这是预期的行为:客户端能够v4.2
,服务器能够v4.2
,然后通过连接v4.2
。
VBox中的内核是5.4:
xavi@iridio:~$ uname -a
Linux iridio 5.4.0-72-generic #80-Ubuntu SMP Mon Apr 12 17:35:00 UTC 2021 x86_64 x86_64 x86_64 GNU/Linux
xavi@iridio:~$
客户端 #2 (Docker)
然后我从主机启动一个基于 raw 的 docker 容器ubuntu:20.04
并安装nfs-common
。以下是完整的会话:
xavi@msi-laptop:~$ # Launch a fresh container from an empty official stock ubuntu image:
xavi@msi-laptop:~$
xavi@msi-laptop:~$ docker run -it --rm --name=nfsclient --hostname=nfsclient --privileged=true ubuntu:20.04
root@nfsclient:/# apt-get update > /dev/null
root@nfsclient:/# apt-get install -y nfs-common > /dev/null
debconf: delaying package configuration, since apt-utils is not installed
root@nfsclient:/#
root@nfsclient:/#
root@nfsclient:/# # Check installed nfs packages. Client is the same than vbox.
root@nfsclient:/#
root@nfsclient:/# apt list --installed | grep nfs
WARNING: apt does not have a stable CLI interface. Use with caution in scripts.
libnfsidmap2/focal,now 0.25-5.1ubuntu1 amd64 [installed,automatic]
nfs-common/focal-updates,focal-security,now 1:1.3.4-2.5ubuntu3.3 amd64 [installed]
root@nfsclient:/#
root@nfsclient:/#
root@nfsclient:/# # Now mount, but does tries 4.2, fails, tries 4.1, fails then 4.0 and succeeds.
root@nfsclient:/#
root@nfsclient:/# mkdir iridio
root@nfsclient:/# mount -vvvv 192.168.3.81:/files/repos/sharedfolder iridio/
mount.nfs: timeout set for Tue May 4 10:55:35 2021
mount.nfs: trying text-based options 'vers=4.2,addr=192.168.3.81,clientaddr=172.17.0.10'
mount.nfs: mount(2): Invalid argument
mount.nfs: trying text-based options 'vers=4.1,addr=192.168.3.81,clientaddr=172.17.0.10'
mount.nfs: mount(2): Invalid argument
mount.nfs: trying text-based options 'vers=4.0,addr=192.168.3.81,clientaddr=172.17.0.10'
root@nfsclient:/# echo $?
0
root@nfsclient:/#
docker 中的内核是 4.19。实际上,docker 引擎在 Windows 10 pro 上的 WSL-2 上的 Ubuntu 20.04 上运行:
root@nfsclient:/# uname -a
Linux nfsclient 4.19.128-microsoft-standard #1 SMP Tue Jun 23 12:58:10 UTC 2020 x86_64 x86_64 x86_64 GNU/Linux
root@nfsclient:/#
问题
- 为什么两个
ubuntu:20.04
具有完全相同版本的nfs-common/focal-updates,focal-security,now 1:1.3.4-2.5ubuntu3.3 amd64
行为方式却一个通过 连接到服务器,v4.2
另一个通过v4.0
? - 该版本是否取决于我拥有的内核?
v4.2
我看到在尝试版本和时显示“参数无效”v4.1
。我是否应该传递任何额外选项才能通过进行连接v4.2
?
答案1
答案就在问题中...
nfs utils 的现代版本将始终默认尝试使用最高的 nfs 版本,截至今天为 4.2。
但是,mount 命令本身并不是 nfs 客户端。因此,它将挂载请求转发给内核。根据内核版本和构建时间选项,不同的内核可以支持不同的 nfs 版本。因此,在某些情况下会立即使用 4.2,而在另一种情况下,内核只是说“不支持”,并让 mout 命令使用不同的 nfs 版本重试。