k8s 网络通讯方式

网络通讯模式-1

Kubernetes 的网络模型假定了所有 Pod 都在一个可以直接连通的扁平的网络空间中,这在 GCE (Google Compute Engine)里面是现成的网络模型,Kubernetes 假定这个网络经存在。而在私有云里搭建 Kubernetes 集群,就不能假定这个网络已经存在了。我们需要自己实现这个网络假设,将不同节点上的 Docker 容器之间的互相访问先打通,然后运行 Kubernetes

网络通讯模式-2

同一个 Pod 内的多个容器之间:lo,共享同一个pod的网络栈,pause容器的网络栈;

各 Pod 之间的通讯:Overlay Network

Pod 与 Service 之间的通讯:各节点的 Iptables 规则,新版本 k8s支持lvs转换

网络解决方案 Kubernetes + Flannel -1

Flannel 是 CoreOS 团队针对 Kubernetes 设计的一个网络规划服务,简单来说,它的功能是让集群中的不同节点主机创建的 Docker 容器都具有全集群唯一的虚拟 IP 地址。而且它还能在这些 IP 地址之间建立一个覆盖网络(Overlay Network),通过这个覆盖网络,将数据包原封不动地传递到目标容器内

网络解决方案 Kubernetes + Flannel -2

image

网络解决方案 Kubernetes + FIanneI -3

ETCD 之 Flanne 提供说明:

  • 存储管理 Flannel 可分配的 IP 地址段资源
  • 监控 ETCD 中每个 Pod 的实际地址,并在内存中建立维护 Pod 节点路由表

不同情下网络通信方式

同一个 Pod 内部通讯:同一个 Pod 共享同一个网络命名空间,共享同一个 Linux 协议栈

Pod1 至 Pod2

  • Pod1 与 Pod2 不在同一台主机,Pod 的地址是与 docker0 在同一个网段的,但 docker0 网段与宿主机网卡是两个完全不同的 IP 网段,并且不同 Node 之间的通信只能通过宿主机的物理网卡进行。将 Pod 的 IP 和所在 Node 的 IP 关联起来,通过这个关联让 Pod 可以互相访问

  • Pod1 与 Pod2 在同一台机器,由 Docker0 网桥直接转发请求至 Pod2, 不需要经过 Flannel

Pod 至 Service 的网络:目前基于性能考虑,全部为 iptables 维护和转发

Pod 到外网:Pod 向外网发送请求,查找路由表,转发数据包到宿主机的网卡,宿主网卡完成路由选择后,iptables 执行 Masquerade,把源 IP 更改为宿主网卡的 IP,然后向外网服务器发送请求

外网访问 Pod: Service

posted @ 2021-09-09 17:47  Star-Hitian  阅读(344)  评论(0)    收藏  举报