负载平衡/VIP 如何与覆盖网络配合使用?

负载平衡/VIP 如何与覆盖网络配合使用?

我正在尝试了解内置 Docker 负载平衡/VIP 如何与覆盖网络配合使用。为了更好地解释我对此的理解,我制作了一个图表。我希望有人可以确认或否定我的理解。

假设我在 Docker Swarm 中运行了两个服务:webserverapi。这两个服务都已扩展到两个实例。这些实例运行在节点A节点B

  1. 世界上有人提出了一个请求,不知何故节点A
  2. iptables节点A请求将DNAT发送到 ingress-sbox节点A
  3. (我们ingress-sbox就把它看作一个黑盒子吧)决定请求应该发送到节点B
  4. ingress-sbox请求发送到“api”覆盖网桥,然后请求通过隧道路由vxlan节点B
  5. Web 服务器容器节点B通过“api”覆盖网络桥接收请求。

这是对于传入请求如何穿越覆盖网络的合理理解吗?

...还有一个后续问题:当请求通过负载均衡器 ( ) 从webserver到 时会发生什么。请求是否始终通过与请求来源相同的主机上的 进行负载平衡?如果是这种情况,我假设这意味着对服务 VIP 的请求始终被路由到在发出请求的同一节点上运行的 ?apiingress-sboxingress-sboxingress-sbox

在此处输入图片描述

相关内容