在Docker卷的NFS4共享中支持文件locking

这里是我docker-compose.yml文件的摘录:

 volumes: nfs_share: driver: local driver_opts: type: nfs o: addr=nfs_server,rw,noatime device: ":/srv/nfs_share" 

卷已正确安装在主机上。

但是,在我的docker实例,我不能使用文件locking。

例:

 # exec 3 > test_file # flock -x 3 flock: 3: No locks available 

如果我在主机上手动挂载分区,我可以使用文件locking没有任何问题。

另外,我看到Docker没有使用正确的协议版本安装NFS共享:

 :/srv/nfs_share on /var/lib/docker/volumes/registry_registry/_data type nfs (rw,relatime,vers=3,rsize=262144,wsize=262144,namlen=255,hard,proto=tcp,timeo=600,retrans=2,sec=sys,mountaddr={MYIPADDR},mountvers=3,mountproto=tcp,local_lock=none,addr={MYIPADDR}) 

但是,如果我在主机上手动挂载分区,则NFS4将被正确使用:

 nfs:/srv/nfs_share on /mnt/nfs_share type nfs4 (rw,relatime,vers=4.0,rsize=262144,wsize=262144,namlen=255,hard,proto=tcp,port=0,timeo=600,retrans=2,sec=sys,clientaddr={MYIPADDR},local_lock=none,addr={MYIPADDR}) 

我尝试添加nolock选项,或local_lock=all ,这些选项似乎被忽略…我也试着指定vers=4.0选项,或使用type: nfs4 …所有这些变体不会改变任何东西。

 volumes: nfs-gemstash: driver: local driver_opts: device: :/nfsdata o: addr=nfs_server_ip,rw,nolock type: nfs 

试试这个,然后使用新的yaml文件直接创build容器。

Interesting Posts