1

我正在运行一个具有 2 个节点的 docker swarm 模式集群,并部署 5 个服务:[ mysql 、 mongo 、 app ] 并希望使用我的管理器节点中的 ansible 脚本来填充数据库。但是我无法从节点获取 Ip 以访问容器中的数据库服务?
例如:mysql -h {{ mysql_service_host }} ....

如何从节点获取容器IP或服务IP?是否可以在 docker swarm 中使用模式主机?

4

1 回答 1

0

对于属于同一网络的服务(容器),您可以简单地使用服务名称。Docker 包含一个处理 ip 解析的 DNS 解析器。您需要使您的服务成为覆盖网络的一部分。覆盖网络可以跨越多个节点。

例如:

services:
  myapp:
    image: myimage:1.0
    deploy:
      replicas: 1
    networks:
      - privnet

  maindb:
    image: mysql
    deploy:
      replicas: 1
    networks:
      - privnet

networks:
  privnet:
    driver: overlay

这将创建一个具有两种服务的覆盖网络。可以在任何节点上创建相应的容器。在哪里都无所谓。它们都将能够相互通信,因为它们是同一个覆盖网络的一部分。在 myapp 中,您可以将maindb其用作 mysql 服务的 DNS。它将由 Docker 解析为 privnet 网络中的正确 ip。

顺便说一句,具有 2 个节点的 swarm 集群没有多大意义。Swarm 需要至少 3 个节点才能使 Raft 共识协议工作。https://raft.github.io

于 2017-04-24T11:17:47.950 回答