Назад | Перейти на главную страницу

NFSv4 не может установить какие-либо сокеты для nfsd без запуска rpcbind

В соответствии с Документы Red Hat 'rpcbind' больше не требуется:

Поскольку поддержка протокола включена в протокол v4, NFSv4 не взаимодействует с демонами portmap, rpc.lockd и rpc.statd. NFSv4 прослушивает хорошо известный TCP-порт 2049, что устраняет необходимость во взаимодействии с картой портов. Протоколы монтирования и блокировки были включены в протокол V4, что устраняет необходимость взаимодействия с rpc.lockd и rpc.statd. Демон rpc.mountd по-прежнему требуется на сервере, но не участвует в каких-либо операциях по сети.

однако я не могу запустить демон NFS, когда служба rpcbind не запущена:

# service nfs start
Starting NFS services:                                     [  OK  ]
Starting NFS quotas: Cannot register service: RPC: Unable to receive; errno = Connection refused
rpc.rquotad: unable to register (RQUOTAPROG, RQUOTAVERS, udp).
                                                           [FAILED]
Starting NFS mountd:                                       [  OK  ]
Starting NFS daemon: rpc.nfsd: writing fd to kernel failed: errno 111 (Connection refused)
rpc.nfsd: unable to set any sockets for nfsd
                                                           [FAILED]

Я отключил NFS v2 и v3:

# grep -v "^#" /etc/sysconfig/nfs
MOUNTD_NFS_V2="no"
MOUNTD_NFS_V3="no"
RPCNFSDARGS="-N 2 -N 3"

Не могли бы вы подтвердить, какие службы требуются / необходимы на сервере и клиенте из перечисленных ниже (в основном я хотел бы отключить службы, которые не нужны):

# rpm -ql nfs-utils | grep 'init.d'
/etc/rc.d/init.d/nfs
/etc/rc.d/init.d/nfslock
/etc/rc.d/init.d/rpcgssd
/etc/rc.d/init.d/rpcidmapd
/etc/rc.d/init.d/rpcsvcgssd

Это была ошибка в модуле ядра сервера NFS. это было залатанный в декабре 2013 г.

Начиная с ядра 3.14, rpcbind больше не требуется для запуска NFS-сервера в ядре.

(при условии, что сервер настроен на использование только NFSv4 и выше)

http://lxr.free-electrons.com/source/net/sunrpc/svc.c?v=3.14#L966

Вы можете найти дополнительную информацию об этом изменении в этой теме:

http://www.spinics.net/lists/linux-nfs/msg41053.html

Следовательно, ваша конфигурация:

MOUNTD_NFS_V2="no"
MOUNTD_NFS_V3="no"
RPCNFSDARGS="-N 2 -N 3"

теперь должен работать без rpcbind.

Когда вы используете только NFSv4, ни одна из этих служб не требуется:

/etc/rc.d/init.d/nfslock
/etc/rc.d/init.d/rpcgssd
/etc/rc.d/init.d/rpcidmapd
/etc/rc.d/init.d/rpcsvcgssd

Цитированная документация RedHat была неправильной и была исправлена Ошибка 521215: rpc.mountd все еще нужно использовать настроить NFSv4, но, строго говоря, после этого запускаться не обязательно.

  • nfs: Сервер для всех версий NFS: v2, v3, v4, v4.1
  • rpcbind/portmapper: Сервер, строго только для NFS <= v3. Но также и для NFS v4, поскольку сервер NFS ядра Linux пытается зарегистрироваться и не запускается, если rpcbind не работает.
  • rpc.mountd: Сервер, строго только для NFS <= 3. Но также и для NFS v4, поскольку ядро ​​Linux использует его для проверки, разрешено ли подключение подключающемуся клиенту.
  • nfslock: Сервер только для NFS <= v3
  • rpc.idmapd: По желанию Сервер (и старше Клиенты) для NFS v4
  • rpc.quotad: Сервер за использование дисковой квоты
  • rpc.statd: Сервер только для NFS <= v3

При использовании Kerberos (sec=krb/krb5i/krb5p) требуются следующие услуги:

  • rpc.gssd: Клиент
  • rpc.svcgssd: Сервер

Обратите внимание, что даже они несут rpc. в своем названии они используют внутренний механизм ядра Linux rpc_pipef для связи между ядром Linux и помощником пользовательского пространства; так rpcbind AKA portmapper им не нужен.

Проверьте службу rpcbind. Если он перестал работать, запустите, а затем попробуйте запустить службу nfs.

service rpcbind start
service nfs start