小编cbo*_*tig的帖子

在 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
Run Code Online (Sandbox Code Playgroud)

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

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

docker run -v /home:/home …
Run Code Online (Sandbox Code Playgroud)

nfs docker coreos

5
推荐指数
2
解决办法
6063
查看次数

标签 统计

coreos ×1

docker ×1

nfs ×1