I'm trying to create an NFS docker volume, however I'm unable to do so by hostname.

I'm creating the volume with:

sudo docker volume create --name foo_bar --driver local \
  --opt type=nfs4 \
  --opt o=addr=foo.lan.domain.xyz,rw,noatime,rsize=8192,wsize=8192,tcp,timeo=14 \
  --opt device=:/volume1/bar

However, when I try to create a docker container which uses this volume, I see:

docker: Error response from daemon: failed to mount local volume: mount :/volume1/bar:/var/lib/docker/volumes/foo_bar/_data, flags: 0x400, data: addr=foo.lan.domain.xyz,rsize=8192,wsize=8192,tcp,timeo=14: invalid argument.

The syslog shows:

kernel: [ 1662.349322] NFS: bad IP address specified: addr=foo.lan.domain.xyz

It seems that NFS is not attempting to resolve the domain name before connecting. This domain name is certainly valid.

$ host foo.lan.domain.xyz
foo.lan.domain.xyz has address 10.0.0.3

$ nslookup foo.lan.domain.xyz
Server:     127.0.0.53
Address:    127.0.0.53#53

Non-authoritative answer:
Name:   foo.lan.domain.xyz
Address: 10.0.0.3

$ showmount -e foo.lan.domain.xyz
Export list for foo.lan.domain.xyz:
/volume1/qux   lore.lan.domain.xyz

$ getent hosts 10.0.0.3
10.0.0.3        Bar.lan.domain.xyz

How can I get NFS to resolve this hostname? I'd really rather not hard code the IP address if it can be helped.


Solution 1:

I saw this because I was dealing with the same issue. I found some further information in the following two bugs

https://github.com/moby/moby/pull/27329

https://github.com/moby/moby/issues/31365

It turns out that docker is always expecting type=nfs and is expecting you to set the version by adding another option. Your command should be

sudo docker volume create --name foo_bar --driver local \
  --opt type=nfs \
  --opt o=addr=foo.lan.domain.xyz,rw,noatime,rsize=8192,wsize=8192,tcp,timeo=14,nfsvers=4 \
  --opt device=:/volume1/bar

You can verify which version the mount is using by executing this command while the container is running

sudo nfsstat -m