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 / 问题 / 647014
Accepted
cboettig
cboettig
Asked: 2014-11-26 10:33:12 +0800 CST2014-11-26 10:33:12 +0800 CST 2014-11-26 10:33:12 +0800 CST

在 CoreOS 集群上通过 NFS 共享磁盘?

  • 772

CoreOS 集群是否可以共享磁盘空间,例如使用 NFS?如果是这样,人们会怎么做呢?(例如,在一个节点有大量磁盘空间的情况下)。例如,这对于避免每个节点必须下载和存储自己的 docker 镜像库或跨节点共享主目录空间很有用。

因为我们不能直接在 CoreOS 中安装额外的软件,我想人们必须编写一个容器来安装 NFS(例如nfs-kernel-server在基于 Ubuntu 的容器上)。

我不知道这是否可能,但我希望有一些既定的方法可以在 CoreOS 集群之间共享磁盘空间(毕竟,这似乎是对集群的普遍期望,也许我下面的建议比必要的更复杂) . 只是为了提供一些反馈意见,这是我到目前为止的想法:

提供 NFS 的主机端似乎是一个合理的 docker 任务,例如我想象一个 Dockerfile 像:

FROM ubuntu:14.04
ENV CLIENT_IP 11.111.111.111          
RUN apt-get update && apt-get install -y nfs-kernel-server supervisor
RUN mkdir /var/nfs && chown nobody:nogroup /var/nfs
RUN echo "/home       ${CLIENT_IP}(rw,sync,no_root_squash,no_subtree_check)" >> /etc/exports
RUN echo "/var/nfs    ${CLIENT_IP}(rw,sync,no_subtree_check)" >> /etc/exports
RUN exportfs -a
CMD service nfs-kernel-server start

在哪里CLIENT_IP正确填写(也许我们需要用调用supervisord或类似方法替换 CMD 以使其持久化,但你明白了)

那么,在运行这个容器时,我们如何适当地链接卷呢?我们将从 CoreOS 主机链接哪个卷?或者我是否需要添加一些内容--net="host"以使客户端可用?

docker run -v /home:/home nfs-server

我完全不清楚我们如何实现客户端,因为我们再次需要一个容器来提供nfs-common,并以某种方式弄清楚其他容器如何共享该资源(也许适当使用--volumes-from?)我'我很乐意看到如何解决这个问题的大纲,或者为什么它不可能以及是否有更好的替代方案来解决这个用例。谢谢!

docker
  • 2 2 个回答
  • 6288 Views

2 个回答

  • Voted
  1. Nemanja Trifunovic
    2015-08-18T09:36:23+08:002015-08-18T09:36:23+08:00

    您需要启动rpc-mountd和systemd 服务并在文件nfsd中定义您的 nfs 导出。/etc/exports

    示例cloud-config.yml:

    coreos:
      units:
        - name: rpc-mountd.service
          command: start
          enable: true
        - name: nfsd.service
          command: start
          enable: truestrong text
    write_files:
      - path: /etc/exports
        permissions: '0644'
        # Change /network-raid with the dir you want to export over nfs
        content: /network-raid/ 192.168.1.0/24(rw,async,no_subtree_check,no_root_squash,fsid=0)
    

    我有这个设置与CoreOS v723.3.0一起使用。

    您可以在以下链接找到更多关于在 CentOS 上通过 NFS 共享磁盘的信息:

    • https://groups.google.com/forum/#!topic/coreos-user/-5_r8sAqyPk
    • http://blog.scottlowe.org/2015/02/20/config-mount-nfs-coreos/
    • 8
  2. Best Answer
    errordeveloper
    2014-11-27T06:22:40+08:002014-11-27T06:22:40+08:00

    您应该能够在 CoreOS 主机上挂载 NFS 卷。如果没有从 CoreOS 导出文件系统的用户级工具,您可以使用该toolbox命令提供的 Fedora 工具箱容器。

    • 3

相关问题

  • 如何调试 docker 容器初始化?

  • 创建后立即启动 Docker 容器?

  • 如何在不指定命令的情况下在 Docker 容器中运行完整的操作系统?

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