docker 集群中文件挂载的问题

假如说在一个三节点的集群上执行

docker 集群中文件挂载的问题

 

docker service create --replicas 2 -p 80:80 --name nginx nginx:1.13.7-alpine

然后访问三个节点的任意一个ip都会看到nginx的欢迎界面。nginx的默认index.html路径在/usr/share/nginx/html/index.html

假如说现在要进行文件挂载,也就是文件路径映射。注意几个问题:

  1. docker service create 里面的文件映射用的命令是 --mount 而不是 -v什么的
  2. 如果源路径是绝对路径要加type=bind
  3. 还有一个地方要清楚,集群里面有三台服务器,那么映射到的路径是当前某个节点机器上的路径,意思就是manager节点会选择某些work节点跑某些容器,而那个容器映射的路径会对应到当前的那个node的本地路径上。具体看下面结果:

执行:

docker service create --replicas 2 -p 80:80 --name nginx --mount type=bind,src=/tmp/index.html,dst=/usr/share/nginx/html/index.html nginx:1.13.7-alpine

然后分别找到这两个容器都是在哪个节点上启动的。

docker ps

找到后,分别登陆到这两个机器上,执行:

echo '<h1>Hello, Dockerxxx!</h1>' > /tmp/index.html

echo '<h1>Hello, Dockerbbbbbbbbbbb!</h1>' > /tmp/index.html

在三个节点上看到的结果是

docker 集群中文件挂载的问题

 

结果并不是固定的,如果清空缓存的话,在刷新同一个ip是可能有不容结果的,至于是什么结果要看集群负载均衡的时候分配的是哪个容器给你,展示的结果就是当前分配容器所在的node上的/tmp/index.html目录里面的内容,比如下面,用微信打开192.168.0.102和浏览器打开并不一样

docker 集群中文件挂载的问题