我有多个运行 Docker 的主机,我使用 Consul 作为键值存储。我能够创建覆盖网络,容器可以看到彼此的主机名和 IP,/etc/hosts 在创建/销毁容器时得到很好的更新。但是,不同主机上的容器实际上无法相互连接(同一主机上的容器可以)。
我一直在调查日志,Docker 守护进程日志包含这些:
[INFO] serf: EventMemberJoin: vagrant-ubuntu-trusty-64 192.168.57.103
[ERR] memberlist: Conflicting address for vagrant-ubuntu-trusty-64. Mine: 192.168.57.103:7946 Theirs: 192.168.57.102:7946
[ERR] serf: Node name conflicts with another node at 192.168.57.102:7946. Names must be unique! (Resolution enabled: true)
Docker 守护进程是否应该以某种方式识别自己?看起来 Serf 很困惑,因为每个守护进程只使用主机名作为标识符。
最佳答案
回答:集群成员需要有唯一的主机名,因为 Docker 守护进程是根据主机名识别的(默认情况下)。为什么 Docker 在他们的教程中忽略了这一点?
关于Docker 容器无法通过覆盖网络连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34769681/