文章目录

  • 前言
  • 1、Kubernetes网络中的挑战
  • 2、Kubernetes的网络模型
  • 3、如何实现Kubernetes网络模型
  • 4、常用网络插件对比
  • 5、Flannel架构图
  • 6、Flannel原理
  • 7、Flannel配置说明
  • 8、Flannel配置样例


前言

网络是Kubernetes的核心部分,这章会对Flannel网络插件进行详细讲解!

1、Kubernetes网络中的挑战

网络是Kubernetes的核心部分,但是要确切地了解其工作方式可能会面临各种挑战,比如:

1、高度耦合的容器间通信:这通过pod和locahost间通信得以解决
2、pod间的通信:这是本章节需要着重讲解的
3、pod到service的通信:这是由service解决的
4、外部流量与service的通信,我们又称之为南北流量的问题:这也是由service解决的

2、Kubernetes的网络模型

通过前几章节的学习,你是否已经发现:
每个Pod都有自己的IP地址,且你无需在Pod之间显式创建链接,也几乎不需要处理将容器端口映射到主机端口的问题。

这样做的好处就在于,可以创建一个干净的、向后兼容的模型,从端口分配,命名,服务发现,负载平衡,应用程序配置和迁移的角度来看,可以将Pod像VM或物理主机一样对待。

所以,Kubernetes的网络的基本要求有以下两个特征:

1、节点上的Pod可以与所有节点上的所有Pod通信,而无需NAT地址转换
2、节点上的代理程序(例如系统守护程序,kubelet)可以与该节点上的所有Pod通信

3、如何实现Kubernetes网络模型

有很多网络插件可以实现我们所描述的Kubernetes网络模型的需求。
下面给大家例出了几个较常用的网络插件,大家可以按需研读:

插件名

备注

文档

Flannel

一个非常简单的覆盖网络,可以满足Kubernetes的要求

Flannel

Kube-router

Kubernetes专用网络解决方案,旨在提供高性能和操作简便性

Kube-router

Calico

Calico提供了高度可扩展的网络和网络策略解决方案

Calico

Weave

可作为CNI插件运行或独立运行,较灵活

Weave

4、常用网络插件对比

1、Flannel(简单、使用居多):基于Vxlan技术(叠加网络+二层隧道),不支持网络策略
2、Calico(较复杂,使用率少于Flannel):也可以支持隧道网络,但是是三层隧道(IPIP),支持网络策略

注意:虽然两者的性能一直各执一词,但主要区别还是在于网络策略的支持上

5、Flannel架构图

kubernetes flannel 网络 kubernetes网络插件_kubernetes

你可以根据之前的配置清单,对比来看这张图,同时也可以通过自己已有环境的规律来学习:

  • pod网络地址的分配情况;
  • node机器的ip分配情况等

6、Flannel原理

原理总结:

1、flannel的网络地址是10.244.0.0/16,默认每个子网的掩码长度为24,如上图所示
2、K8s节点之间(Node)通过Vxlan技术进行通信。根据node情况,会把flannel的16位网络地址拆分成多个24位网络地址,供各Node进行分配
3、每个Node节点按序占用一个C类地址,对应节点上面的Podip是在该C类地址中按规则分配的。

7、Flannel配置说明

SubnetLen:

定义每个子网的掩码长度,默认为24。
那么10.244.0.0/16就会被分成2^(24-16)-2=254个子网,就说明此时K8s集群
最大支持254个节点(Node),其中每个Node节点都能使用一个子网,每个子网可以分配多少个主机位就代表每个Node节点上可以运行的Pod最大数量:[2^(32-24)-2=254个]

SubnetMin:

定义Pod网络的起始,默认是从10.244.0.0/24开始,也可以定义从10.244.10.0/24开始,也不一定要使用10开始的网络

SubnetMax:

与上面相反,定义Pod网络的结束

大家也可以在Flannel官方配置说明中找到具体配置说明。

8、Flannel配置样例

此时你应该很容易能看懂,我就不再赘述了。

{
    "Network": "10.0.0.0/8",
    "SubnetLen": 20,
    "SubnetMin": "10.10.0.0",
    "SubnetMax": "10.99.0.0",
    "Backend": {
        "Type": "udp",
        "Port": 7890
    }
}