Почему NFS не позволяет мне смонтировать общий ресурс?

Хост

У меня есть хост с Ubuntu 12.04 в 10.0.0.202. Он предоставляет общий ресурс NFS для других компьютеров в сети. Вот содержимое /etc/exports:

/media/storagedrive 10.0.0.0/24(rw,sync,no_subtree_check)

Здесь мы хотим поделиться содержимым /media/storagedrive с другими машинами в сети в диапазоне IP 10.0.0.0 - 10.0.0.255.

Рабочий клиент

Это правильно работает с клиентским компьютером по адресу 10.0.0.40, на котором работает Ubuntu 13.10, известная как MattDev. /etc/fstab этой машины выглядит следующим образом:

UUID=8f8c838e-3ea2-457a-87f0-57b12dfab06c /               ext4    errors=remount-ro 0       1
UUID=427089d4-46a2-432d-9df4-7016bdfc7df2 none            swap    sw              0       0
10.0.0.202:/media/storagedrive /mnt/NetworkStorageDrive nfs rsize=8192,wsize=8192,timeo=14,intr

И ls -al /mnt/ на этой машине выглядит следующим образом:

total 12K
drwxr-xr-x  3 root root    4.0K Feb  4 17:48 .
drwxr-xr-x 23 root root    4.0K Feb  5 08:44 ..
drwxrwxr-x  7 root plugdev 4.0K Feb  5 11:43 NetworkStorageDrive

Вывод id выглядит следующим образом:

uid=1000(matt) gid=1000(matt) groups=1000(matt),4(adm),24(cdrom),27(sudo),30(dip),33(www-data),46(plugdev),112(lpadmin),124(sambashare)

Неработающий виртуальный клиент

У меня есть второй клиентский компьютер с Ubuntu 12.10 в качестве гостевой ОС на хост-компьютере Windows 7. Хост-машина находится в сети как 10.0.0.28. Гостевая машина управляется Vagrant, используя VirtualBox 4.3.6 в качестве поставщика. Я позвоню хосту Windows 7 AlexDevHost и гостю Ubuntu AlexDevGuest.

Запуск showmount -e 10.0.0.202 на AlexDevGuest приводит к:

Export list for 10.0.0.202:
/media/storagedrive 10.0.0.0/24

Однако, когда я пытаюсь смонтировать общий ресурс, происходит сбой:

$ sudo mount 10.0.0.202:/media/storagedrive /mnt/NetworkStorageDrive
mount.nfs: access denied by server while mounting 10.0.0.202:/media/storagedrive

Поэтому я начал искать проблемы:

$ ls -alh /mnt/
total 12K
drwxr-xr-x  3 root root 4.0K Feb  5 12:23 .
drwxr-xr-x 26 root root 4.0K Feb  5 12:23 ..
drwxr-xr-x  2 root root 4.0K Feb  5 12:23 NetworkStorageDrive
$ id
uid=1001(vagrant) gid=1001(vagrant) groups=1001(vagrant)
$

Этот uid и gid отличается от пользователя matt на MattDev. Поэтому я передергивал uid для vagrant, поскольку я читал, что доступ к NFS контролируется путем сопоставления IP-адреса и uids. Так что теперь:

$ id
uid=1000(vagrant) gid=1001(vagrant) groups=1001(vagrant)
$ sudo mount 10.0.0.202:/media/storagedrive /mnt/NetworkStorageDrive
mount.nfs: access denied by server while mounting 10.0.0.202:/media/storagedrive
$

Все еще безуспешно. Так что теперь у меня заканчиваются идеи.

  1. Что я делаю не так?
  2. Если часть uid верна, можно ли проверить, что машина NFS-сервера видит мою попытку доступа как поступающую из 10.0.0.28, и какой-то другой IP-адрес не находится в допустимом диапазоне?
14
задан 5 February 2014 в 18:01

1 ответ

Хорошо, я решил это (или, по крайней мере, я заставил это работать, и я думаю, что я знаю, что вызвало это).

Я добавил флаг insecure в строку /etc/exports на сервере NFS, поэтому теперь он выглядит следующим образом:

/media/storagedrive 10.0.0.0/24(rw,sync,no_subtree_check,insecure)

Этот флаг позволяет устанавливать соединения с клиентских портов выше IPPORT_RESERVED (1024). ).

Команда mount теперь работает.

Я полагаю, почему проблема с отсутствием флага insecure заключалась в том, что VirtualBox использовал NAT для передачи запроса в физическую сеть, поэтому порт гостевой системы Ubuntu (AlexDevGuest) мог быть ниже 1024, переведенный порт на хосте Windows 7 (AlexDevHost), вероятно, был выше 1024 и поэтому заблокирован. Установка флага insecure означала, что он был разрешен.

Эта проблема, очевидно, не затрагивает не виртуальную машину DevMatt.

0
ответ дан 5 February 2014 в 18:01

Другие вопросы по тегам:

Похожие вопросы: