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

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

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?)我很想看看如何做到这一点的概述,或者为什么这是不可能的,以及是否有更好的替代方案来解决这个用例。谢谢!

答案1

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

答案2

您需要启动systemd 服务rpc-mountd并在文件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 共享磁盘的更多信息:

相关内容