2

我正在使用 docker-compose.yml 文件(Swarm stack deploy)将 2 个容器(应用程序和 SQL)部署到同一个网络。大多数情况下,应用程序通过它的主机名作为连接字符串中的数据源与 SQL 通信没有问题。

但是,有时它根本找不到它。为了调试它,我已经验证了每个节点中确实创建了overlay网络,并且在检查每个节点上的网络时,我看到容器确实属于这个网络。

此外,当我运行docker exec命令进入应用程序容器时,我尝试向 SQL 容器发送 ping,主机名确实解析到正确的 IP,但仍然没有响应。

这非常令人沮丧,因为它只是不时发生。关于如何调试问题的任何建议?

version: '3.2'
services:
  sqlserver:
   image: xxxx:5000/sql_image
   hostname: sqlserver
   deploy: 
     endpoint_mode: dnsrr
   networks:
      devnetwork:
        aliases:
            - sqlserver

  test:
    image: xxxx:5000/test
    deploy: 
     endpoint_mode: dnsrr
    deploy:
     restart_policy:
        condition: none
     resources:
        reservations:
          memory: 2048M
    networks:
      - devnetwork

networks:
    devnetwork:
        driver: overlay
4

1 回答 1

1

负载时的服务发现和 DNS 问题在 swarm 模式下是已知的。我们经常遇到这个问题。您可以在此处此处发现未解决的问题。

如果您运行大量使用网络应用程序,请考虑将您的工作节点和管理节点分开。这将有助于经理很好地执行服务发现。

您可以更改服务发现组件并使用ConsulZooKeeper作为堆栈实现的一部分。

我会考虑使用一些服务网格来进行服务之间的数据绑定通信。领事可以为你做。您可以从这种设计模式中获得很多好处。例如,安全和加密数据通信。

于 2019-03-01T07:16:52.337 回答