在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容器。