首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >NFS4共享的Docker卷中的文件锁定支持

NFS4共享的Docker卷中的文件锁定支持
EN

Stack Overflow用户
提问于 2017-05-11 20:00:37
回答 1查看 3.1K关注 0票数 4

下面是我的docker-compose.yml文件的摘录:

代码语言:javascript
复制
volumes:
  nfs_share:
    driver: local
    driver_opts:
      type: nfs
      o: addr=nfs_server,rw,noatime
      device: ":/srv/nfs_share"

该卷已正确装载到主机上。

然而,在我的docker实例中,我不能使用文件锁。

示例:

代码语言:javascript
复制
# exec 3 > test_file
# flock -x 3
flock: 3: No locks available

如果我在主机上手动挂载分区,则可以使用文件锁而不会出现任何问题。

另外,我发现Docker没有使用正确的协议版本挂载NFS共享:

代码语言:javascript
复制
:/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:

代码语言:javascript
复制
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…所有这些变体都不会改变任何东西。

EN

回答 1

Stack Overflow用户

发布于 2017-09-30 18:18:03

代码语言:javascript
复制
volumes:
  nfs-gemstash:
    driver: local
    driver_opts:
      device: :/nfsdata
      o: addr=nfs_server_ip,rw,nolock
      type: nfs

尝试这样做,然后使用新的yaml文件直接创建容器。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43914819

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档