AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1023585
Accepted
mr.simonski
mr.simonski
Asked: 2020-07-02 02:28:22 +0800 CST2020-07-02 02:28:22 +0800 CST 2020-07-02 02:28:22 +0800 CST

NFS 共享上的 Docker 卷 - 空目录

  • 772

我们的业务应用程序在两个节点(node1 和 node2)上运行了一个 Docker Swarm 部署。

应用程序需要一个卷来存储持久数据。由于不清楚容器的部署位置(节点 1 或节点 2),以及我们的应用程序的两个容器可能应该在两个节点上运行,我们需要一个解决方案来为所有节点提供共享卷。

为了共享卷,我们使用以下 /etc/exports 文件在第三个节点 3 上设置 NFS 服务器:

/srv          *(rw,sync,anonuid=1000,anongid=1000,all_squash,subtree_check,crossmnt,fsid=root)

(我使用 anonuid/gid 为导出中的每个文件显式设置 node3 系统中已知用户的用户信息。all_squash 用于确保所有访问用户的所有文件权限都重写给该本地用户)

在我们的 docker-compose.yml 中,我们使用以下设置来包含卷:

volumes:
  nfs-data:
    driver: local
    driver_opts:
      type: nfs
      o: nfsvers=4,addr=node3.example.com,rw,nolock,soft

我们现在遇到了容器不想启动的问题,错误消息是:

failed to copy file info for /var/lib/docker/volumes/MY_CONTAINER_nfs-data/_data: failed to chown /var/lib/docker/volumes/MY_CONTAINER_nfs-data/_data: lchown /var/lib/docker/volumes/MY_CONTAINER_nfs-data/_data: operation not permitted

经过一番挖掘,我发现问题出在 node3 服务器上导出的 NFS 目录上的初始空文件夹中。一旦我放入一个空文件,node1 和 node2 中的容器的启动就完全正常了。

有人对此有解释吗?

nfs share docker nfs4
  • 1 1 个回答
  • 1869 Views

1 个回答

  • Voted
  1. Best Answer
    BMitch
    2020-07-02T04:29:39+08:002020-07-02T04:29:39+08:00

    当命名卷从空/新状态初始化时,docker 会将镜像目录的内容复制到命名卷中。有几种选择可以解决这个问题:

    1. 在容器启动之前使用内容初始化命名卷。如您所见,这会禁用卷初始化步骤。
    2. 更新图像以在目录中具有所需的 uid/gid 并包含带有RUN chown -R 1000:1000 /path. 这应该可以防止出现问题,但您需要进行测试以确保没有 chown 试图从 docker 运行,具体取决于它如何初始化这些文件。
    3. 在 NFS 上禁用 squash。这是 docker 卷问题的常见原因,我不确定您会获得什么安全优势。如果您确实需要避免使用 root,您可以尝试使用用户命名空间配置 docker,但这会破坏您假设 uid 匹配的主机卷,因此请准备好一些努力。
    4. 禁用卷初始化。使用当前的 compose spec,您可以使用长语法将“nocopy”选项添加到您的服务量规范中。这是在使用卷的服务上完成的,而不是在定义卷的顶层。

    docker 文档中关于“nocopy”选项的示例如下所示:

    version: "3.8"
    services:
      web:
        image: nginx:alpine
        ports:
          - "80:80"
        volumes:
          - type: volume
            source: mydata
            target: /data
            volume:
              nocopy: true
    
    volumes:
      mydata:
    
    • 4

相关问题

  • 在 NFS 文件服务器上获取不规则时间戳

  • 过时的 NFS 句柄

  • sh 脚本:如果未安装远程文件系统,如何安装它?

  • 分析 Linux NFS 服务器性能

  • NFS 缓存导致间歇性滞后

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve