0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Kubernetes中的网络模型

jf_TEuU2tls 来源:浩道linux 作者:浩道linux 2022-12-14 10:07 次阅读

前言

Overview

本文将探讨 Kubernetes 中的网络模型,以及对各种网络模型进行分析。

Underlay Network Model

什么是 Underlay Network

底层网络Underlay Network顾名思义是指网络设备基础设施,如交换机,路由器,DWDM使用网络介质将其链接成的物理网络拓扑,负责网络之间的数据包传输。

a3bfc34a-7b4c-11ed-8abf-dac502259ad0.pngUnderlay network topology

underlay network可以是二层,也可以是三层;二层的典型例子是以太网Ethernet,三层是的典型例子是互联网Internet

而工作于二层的技术是vlan,工作在三层的技术是由OSPF,BGP等协议组成。

k8s 中的 underlay network

在 kubernetes 中,underlay network中比较典型的例子是通过将宿主机作为路由器设备,Pod 的网络则通过学习路由条目从而实现跨节点通讯。

a3d37be2-7b4c-11ed-8abf-dac502259ad0.pngunderlay network topology in kubernetes

这种模型下典型的有flannelhost-gw模式与calicoBGP模式。

flannel host-gw

flannel host-gw模式中每个 Node 需要在同一个二层网络中,并将 Node 作为一个路由器,跨节点通讯将通过路由表方式进行,这样方式下将网络模拟成一个underlay network

a3df1fd8-7b4c-11ed-8abf-dac502259ad0.pnglayer2 ethernet topology

Notes:因为是通过路由方式,集群的 cidr 至少要配置 16,因为这样可以保证,跨节点的 Node 作为一层网络,同节点的 Pod 作为一个网络。如果不是这种用情况,路由表处于相同的网络中,会存在网络不可达

Calico BGP

BGP(Border Gateway Protocol)是去中心化自治路由协议。它是通过维护 IP 路由表或前缀表来实现 AS (Autonomous System)之间的可访问性,属于向量路由协议。

a3ee6dd0-7b4c-11ed-8abf-dac502259ad0.pngBGP network topology

flannel不同的是,Calico提供了的BGP网络解决方案,在网络模型上,CalicoFlannel host-gw是近似的,但在软件架构的实现上,flannel使用flanneld进程来维护路由信息;而Calico是包含多个守护进程的,其中Brid进程是一个BGP客户端与路由反射器(Router Reflector),BGP客户端负责从Felix中获取路由并分发到其他BGP Peer,而反射器在 BGP 中起了优化的作用。在同一个 IBGP 中,BGP 客户端仅需要和一个RR相连,这样减少了AS内部维护的大量的 BGP 连接。通常情况下,RR是真实的路由设备,而Bird作为BGP客户端工作。

a3fcb5ac-7b4c-11ed-8abf-dac502259ad0.pngCalico Network Architecture

IPVLAN & MACVLAN

IPVLANMACVLAN是一种网卡虚拟化技术,两者之间的区别为,IPVLAN允许一个物理网卡拥有多个 IP 地址,并且所有的虚拟接口用同一个 MAC 地址;而MACVLAN则是相反的,其允许同一个网卡拥有多个 MAC 地址,而虚拟出的网卡可以没有 IP 地址。

因为是网卡虚拟化技术,而不是网络虚拟化技术,本质上来说属于Overlay network,这种方式在虚拟化环境中与Overlay network相比最大的特点就是可以将 Pod 的网络拉平到 Node 网络同级,从而提供更高的性能、低延迟的网络接口。本质上来说其网络模型属于下图中第二个。

a40ad8da-7b4c-11ed-8abf-dac502259ad0.pngVirtual networking modes: bridging, multiplexing and SR-IOV
  • 虚拟网桥:创建一个虚拟网卡对(veth pair),一头在容器内,一头在宿主机的 root namespaces 内。这样一来容器内发出的数据包可以通过网桥直接进入宿主机网络栈,而发往容器的数据包也可以经过网桥进入容器。
  • 多路复用:使用一个中间网络设备,暴露多个虚拟网卡接口,容器网卡都可以介入这个中间设备,并通过 MAC/IP 地址来区分 packet 应该发往哪个容器设备。
  • 硬件交换,为每个 Pod 分配一个虚拟网卡,这样一来,Pod 与 Pod 之间的连接关系就会变得非常清晰,因为近乎物理机之间的通信基础。如今大多数网卡都支持 SR-IOV 功能,该功能将单一的物理网卡虚拟成多个 VF 接口,每个 VF 接口都有单独的虚拟 PCIe 通道,这些虚拟的 PCIe 通道共用物理网卡的 PCIe 通道。

在 kubernetes 中IPVLAN这种网络模型下典型的 CNI 有,multus 与 danm。

multus

multusintel 开源的 CNI 方案,是由传统的cnimultus,并且提供了 SR-IOV CNI 插件使 K8s pod 能够连接到 SR-IOV VF 。这是使用了IPVLAN/MACVLAN的功能。

当创建新的 Pod 后,SR-IOV 插件开始工作。配置 VF 将被移动到新的 CNI 名称空间。该插件根据 CNI 配置文件中的 “name” 选项设置接口名称。最后将 VF 状态设置为 UP。

下图是一个 Multus 和 SR-IOV CNI 插件的网络环境,具有三个接口的 pod。

  • eth0flannel网络插件,也是作为 Pod 的默认网络
  • VF 是主机的物理端口ens2f0的实例化。这是英特尔 X710-DA4 上的一个端口。在 Pod 端的 VF 接口名称为south0
  • 这个 VF 使用了 DPDK 驱动程序,此 VF 是从主机的物理端口ens2f1实例化出的。这个是英特尔 X710-DA4 上另外一个端口。Pod 内的 VF 接口名称为north0。该接口绑定到 DPDK 驱动程序vfio-pci
a4216410-7b4c-11ed-8abf-dac502259ad0.pngMutus networking Architecture overlay and SR-IOV

Notes:术语

  • NIC:network interface card,网卡
  • SR-IOV:single root I/O virtualization,硬件实现的功能,允许各虚拟机间共享 PCIe 设备。
  • VF:Virtual Function,基于 PF,与 PF 或者其他 VF 共享一个物理资源。
  • PF:PCIe Physical Function,拥有完全控制 PCIe 资源的能力
  • DPDK:Data Plane Development Kit

于此同时,也可以将主机接口直接移动到 Pod 的网络名称空间,当然这个接口是必须存在,并且不能是与默认网络使用同一个接口。这种情况下,在普通网卡的环境中,就直接将 Pod 网络与 Node 网络处于同一个平面内了。

a4335be8-7b4c-11ed-8abf-dac502259ad0.pngMutus networking Architecture overlay and ipvlan

danm

DANM 是诺基亚开源的 CNI 项目,目的是将电信级网络引入 kubernetes 中,与 multus 相同的是,也提供了 SR-IOV/DPDK 的硬件技术,并且支持 IPVLAN.

Overlay Network Model

什么是 Overlay

叠加网络是使用网络虚拟化技术,在underlay网络上构建出的虚拟逻辑网络,而无需对物理网络架构进行更改。本质上来说,overlay network使用的是一种或多种隧道协议 (tunneling),通过将数据包封装,实现一个网络到另一个网络中的传输,具体来说隧道协议关注的是数据包(帧)。

a486c030-7b4c-11ed-8abf-dac502259ad0.pngoverlay network topology

常见的网络隧道技术

  • 通用路由封装 (Generic Routing Encapsulation) 用于将来自 IPv4/IPv6 的数据包封装为另一个协议的数据包中,通常工作与 L3 网络层中。
  • VxLAN (Virtual Extensible LAN),是一个简单的隧道协议,本质上是将 L2 的以太网帧封装为 L4 中 UDP 数据包的方法,使用4789作为默认端口。VxLAN也是VLAN的扩展,对于 4096(位VLAN ID) 扩展为 1600 万(位VN·ID)个逻辑网络。

这种工作在overlay模型下典型的有flannelcalico中的的VxLAN,IPIP模式。

IPIP

IP in IP也是一种隧道协议,与VxLAN类似的是,IPIP的实现也是通过 Linux 内核功能进行的封装。IPIP需要内核模块ipip.ko使用命令查看内核是否加载 IPIP 模块lsmod | grep ipip;使用命令modprobe ipip加载。

a4af8a6a-7b4c-11ed-8abf-dac502259ad0.pngA simple IPIP network workflow

Kubernetes 中IPIPVxLAN类似,也是通过网络隧道技术实现的。与VxLAN差别就是,VxLAN本质上是一个 UDP 包,而IPIP则是将包封装在本身的报文包上。

a4be5400-7b4c-11ed-8abf-dac502259ad0.pngIPIP in kubernetesa4dab8d4-7b4c-11ed-8abf-dac502259ad0.pngIPIP packet with wireshark unpack

Notes:公有云可能不允许 IPIP 流量,例如 Azure

VxLAN

kubernetes 中不管是flannel还是calicoVxLAN 的实现都是使用 Linux 内核功能进行的封装,Linux 对 vxlan 协议的支持时间并不久,2012 年 Stephen Hemminger 才把相关的工作合并到 kernel 中,并最终出现在 kernel 3.7.0 版本。为了稳定性和很多的功能,你可以会看到某些软件推荐在 3.9.0 或者 3.10.0 以后版本的 kernel 上使用VxLAN

a4ebe8a2-7b4c-11ed-8abf-dac502259ad0.pngA simple VxLAN network topology

在 kubernetes 中 vxlan 网络,例如flannel,守护进程会根据 kubernetes 的 Node 而维护VxLAN,名称为flannel.1这是VNID,并维护这个网络的路由,当发生跨节点的流量时,本地会维护对端VxLAN设备的 MAC 地址,通过这个地址可以知道发送的目的端,这样就可以封包发送到对端,收到包的对端 VxLAN 设备flannel.1解包后得到真实的目的地址。

查看Forwarding database列表

$bridgefdb
268791:fcdevflannel.1dst10.0.0.3selfpermanent
a50a4afe-7b4c-11ed-8abf-dac502259ad0.pngVxLAN in kubernetesa52e9350-7b4c-11ed-8abf-dac502259ad0.pngVxLAN packet with wireshark unpack

Notes:VxLAN 使用的 4789 端口,wireshark 应该是根据端口进行分析协议的,而 flannel 在 linux 中默认端口是 8472,此时抓包仅能看到是一个 UDP 包。

通过上述的架构可以看出,隧道实际上是一个抽象的概念,并不是建立的真实的两端的隧道,而是通过将数据包封装成另一个数据包,通过物理设备传输后,经由相同的设备(网络隧道)进行解包实现网络的叠加。

weave vxlan

weave 也是使用了VxLAN技术完成的包的封装,这个技术在weave中称之为fastdp (fast data path),与calicoflannel中用到的技术不同的,这里使用的是 Linux 内核中的openvswitch datapath module,并且 weave 对网络流量进行了加密。

a55bf098-7b4c-11ed-8abf-dac502259ad0.pngweave fastdp network topology

Notes:fastdp 工作在 Linux 内核版本 3.12 及更高版本,如果低于此版本的例如 CentOS7,weave 将工作在用户空间,weave 中称之为sleeve mode


审核编辑 :李倩


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 以太网
    +关注

    关注

    40

    文章

    5424

    浏览量

    171702
  • Linux
    +关注

    关注

    87

    文章

    11304

    浏览量

    209483

原文标题:【硬核系列】看看人家图解K8S网络,那叫通透易懂!

文章出处:【微信号:浩道linux,微信公众号:浩道linux】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    OSI七层模型网络故障排查的应用

    OSI(Open Systems Interconnection)七层模型网络故障排查扮演着至关重要的角色。它提供了一个系统的框架,使得网络技术人员可以逐层分析并定位
    的头像 发表于 11-24 11:01 383次阅读

    如何理解OSI七层模型 OSI七层模型网络的应用

    ,旨在帮助不同计算机系统之间实现互操作性。OSI模型网络通信过程划分为七个层次,每一层都有其特定的功能和协议。以下是对OSI七层模型的简要介绍以及它们在网络
    的头像 发表于 11-24 10:48 352次阅读

    使用Velero备份Kubernetes集群

    Velero 是 heptio 团队(被 VMWare 收购)开源的 Kubernetes 集群备份、迁移工具。
    的头像 发表于 08-05 15:43 361次阅读
    使用Velero备份<b class='flag-5'>Kubernetes</b>集群

    经典卷积网络模型介绍

    经典卷积网络模型在深度学习领域,尤其是在计算机视觉任务,扮演着举足轻重的角色。这些模型通过不断演进和创新,推动了图像处理、目标检测、图像生成、语义分割等多个领域的发展。以下将详细探讨
    的头像 发表于 07-11 11:45 522次阅读

    三层神经网络模型的优缺点

    三层神经网络模型是一种常见的深度学习模型,它由输入层、两个隐藏层和输出层组成。本文将介绍三层神经网络模型的优缺点,以及其在实际应用
    的头像 发表于 07-11 10:58 581次阅读

    pytorch中有神经网络模型

    当然,PyTorch是一个广泛使用的深度学习框架,它提供了许多预训练的神经网络模型。 PyTorch的神经网络模型 1. 引言 深度学习是
    的头像 发表于 07-11 09:59 700次阅读

    PyTorch神经网络模型构建过程

    PyTorch,作为一个广泛使用的开源深度学习库,提供了丰富的工具和模块,帮助开发者构建、训练和部署神经网络模型。在神经网络模型,输出层是
    的头像 发表于 07-10 14:57 502次阅读

    基于神经网络的语言模型有哪些

    文本或预测文本的下一个词。随着深度学习技术的飞速发展,涌现出了多种不同类型的神经网络语言模型。以下将详细介绍几种主流的基于神经网络的语言模型
    的头像 发表于 07-10 11:15 744次阅读

    rnn是什么神经网络模型

    RNN(Recurrent Neural Network,循环神经网络)是一种具有循环结构的神经网络模型,它能够处理序列数据,并对序列的元素进行建模。RNN在自然语言处理、语音识别、
    的头像 发表于 07-05 09:50 609次阅读

    循环神经网络有哪些基本模型

    循环神经网络(Recurrent Neural Networks,简称RNN)是一种具有循环结构的神经网络,它能够处理序列数据,并且能够捕捉序列数据的时序信息。RNN的基本模型有很多
    的头像 发表于 07-04 14:43 435次阅读

    如何使用PyTorch建立网络模型

    PyTorch是一个基于Python的开源机器学习库,因其易用性、灵活性和强大的动态图特性,在深度学习领域得到了广泛应用。本文将从PyTorch的基本概念、网络模型构建、优化方法、实际应用等多个方面,深入探讨使用PyTorch建立网络
    的头像 发表于 07-02 14:08 415次阅读

    助听器降噪神经网络模型

    在堆栈网络方法,参数少于一百万个。该模型使用挑战组织者提供的 500 小时的嘈杂语音进行训练。 该网络能够进行实时处理(一帧输入,一帧输 出)并达到有竞争力的结果。将这两种类型的信号
    发表于 05-11 17:15

    Kubernetes Gateway API攻略教程

    Kubernetes Gateway API 刚刚 GA,旨在改进将集群服务暴露给外部的过程。这其中包括一套更标准、更强大的 API资源,用于管理已暴露的服务。在这篇文章,我将介绍 Gateway
    的头像 发表于 01-12 11:32 894次阅读
    <b class='flag-5'>Kubernetes</b> Gateway API攻略教程

    配置KubernetesPod使用代理的两种常见方式

    在企业网络环境中进行Kubernetes集群的管理时,经常会遇到需要配置Pods通过HTTP代理服务器访问Internet的情况。这可能是由于各种原因,如安全策略限制、网络架构要求或者访问特定资源
    的头像 发表于 01-05 11:22 1147次阅读
    配置<b class='flag-5'>Kubernetes</b><b class='flag-5'>中</b>Pod使用代理的两种常见方式

    使用Jenkins和单个模板部署多个Kubernetes组件

    在持续集成和部署,我们通常需要部署多个实例或组件到Kubernetes集群。通过Jenkins的管道脚本,我们可以自动化这个过程。在本文中,我将演示如何使用Jenkins Pipeline及单个
    的头像 发表于 01-02 11:40 772次阅读
    使用Jenkins和单个模板部署多个<b class='flag-5'>Kubernetes</b>组件