本文将探讨 Kubernetes 中的网络模型,以及对各种网络模型进行分析。
底层网络 Underlay Network
顾名思义是指网络设备基础设施,如交换机,路由器, DWDM
使用网络介质将其链接成的物理网络拓扑,负责网络之间的数据包传输。
Underlay network topology
underlay network
可以是二层,也可以是三层;二层的典型例子是以太网 Ethernet
,三层是的典型例子是互联网 Internet
。
而工作于二层的技术是 vlan
,工作在三层的技术是由 OSPF
, BGP
等协议组成。
在 kubernetes 中,underlay network
中比较典型的例子是通过将宿主机作为路由器设备,Pod 的网络则通过学习路由条目从而实现跨节点通讯。
underlay network topology in kubernetes
这种模型下典型的有 flannel
的 host-gw
模式与 calico``BGP
模式。
flannel host-gw
模式中每个 Node 需要在同一个二层网络中,并将 Node 作为一个路由器,跨节点通讯将通过路由表方式进行,这样方式下将网络模拟成一个underlay network
。
layer2 ethernet topology
Notes:因为是通过路由方式,集群的 cidr 至少要配置 16,因为这样可以保证,跨节点的 Node 作为一层网络,同节点的 Pod 作为一个网络。如果不是这种用情况,路由表处于相同的网络中,会存在网络不可达
BGP(Border Gateway Protocol
)是去中心化自治路由协议。它是通过维护 IP 路由表或前缀
表来实现 AS (Autonomous System
)之间的可访问性,属于向量路由协议。
BGP network topology
与 flannel
不同的是,Calico
提供了的 BGP
网络解决方案,在网络模型上,Calico
与 Flannel host-gw
是近似的,但在软件架构的实现上,flannel
使用 flanneld
进程来维护路由信息;而 Calico
是包含多个守护进程的,其中 Brid
进程是一个 BGP
客户端与路由反射器(Router Reflector
),BGP
客户端负责从 Felix
中获取路由并分发到其他 BGP Peer
,而反射器在 BGP 中起了优化的作用。在同一个 IBGP 中,BGP 客户端仅需要和一个 RR
相连,这样减少了AS
内部维护的大量的 BGP 连接。通常情况下,RR
是真实的路由设备,而 Bird
作为 BGP
客户端工作。
Calico Network Architecture
IPVLAN
和 MACVLAN
是一种网卡虚拟化技术,两者之间的区别为, IPVLAN
允许一个物理网卡拥有多个 IP 地址,并且所有的虚拟接口用同一个 MAC 地址;而 MACVLAN
则是相反的,其允许同一个网卡拥有多个 MAC 地址,而虚拟出的网卡可以没有 IP 地址。
因为是网卡虚拟化技术,而不是网络虚拟化技术,本质上来说属于 Overlay network
,这种方式在虚拟化环境中与 Overlay network
相比最大的特点就是可以将 Pod 的网络拉平到 Node 网络同级,从而提供更高的性能、低延迟的网络接口。本质上来说其网络模型属于下图中第二个。
Virtual networking modes: bridging, multiplexing and SR-IOV
在 kubernetes 中 IPVLAN
这种网络模型下典型的 CNI 有,multus 与 danm。
multus
是 intel 开源的 CNI 方案,是由传统的 cni
与 multus
,并且提供了 SR-IOV CNI 插件使 K8s pod 能够连接到 SR-IOV VF 。这是使用了 IPVLAN/MACVLAN
的功能。
当创建新的 Pod 后,SR-IOV 插件开始工作。配置 VF 将被移动到新的 CNI 名称空间。该插件根据 CNI 配置文件中的 “name” 选项设置接口名称。最后将 VF 状态设置为 UP。
下图是一个 Multus 和 SR-IOV CNI 插件的网络环境,具有三个接口的 pod。
eth0
是 flannel
网络插件,也是作为 Pod 的默认网络ens2f0
的实例化。这是英特尔 X710-DA4 上的一个端口。在 Pod 端的 VF 接口名称为 south0
。ens2f1
实例化出的。这个是英特尔 ® X710-DA4 上另外一个端口。Pod 内的 VF 接口名称为 north0
。该接口绑定到 DPDK 驱动程序 vfio-pci
。Mutus 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 网络处于同一个平面内了。
Mutus networking Architecture overlay and ipvlan
DANM 是诺基亚开源的 CNI 项目,目的是将电信级网络引入 kubernetes 中,与 multus 相同的是,也提供了 SR-IOV/DPDK 的硬件技术,并且支持 IPVLAN.
叠加网络是使用网络虚拟化技术,在 underlay
网络上构建出的虚拟逻辑网络,而无需对物理网络架构进行更改。本质上来说,overlay network
使用的是一种或多种隧道协议 (tunneling
),通过将数据包封装,实现一个网络到另一个网络中的传输,具体来说隧道协议关注的是数据包(帧)。
overlay network topology
Generic Routing Encapsulation
) 用于将来自 IPv4/IPv6 的数据包封装为另一个协议的数据包中,通常工作与 L3 网络层中。Virtual Extensible LAN
),是一个简单的隧道协议,本质上是将 L2 的以太网帧封装为 L4 中 UDP 数据包的方法,使用 4789 作为默认端口。VxLAN
也是 VLAN
的扩展,对于 4096( 位 VLAN ID
) 扩展为 1600 万( 位 VN·ID
)个逻辑网络。这种工作在 overlay
模型下典型的有 flannel
与 calico
中的的 VxLAN
, IPIP
模式。
IP in IP
也是一种隧道协议,与 VxLAN
类似的是,IPIP
的实现也是通过 Linux 内核功能进行的封装。IPIP
需要内核模块 ipip.ko
使用命令查看内核是否加载 IPIP 模块lsmod | grep ipip
;使用命令modprobe ipip
加载。
A simple IPIP network workflow
Kubernetes 中 IPIP
与 VxLAN
类似,也是通过网络隧道技术实现的。与 VxLAN
差别就是,VxLAN
本质上是一个 UDP 包,而 IPIP
则是将包封装在本身的报文包上。
IPIP in kubernetes
IPIP packet with wireshark unpack
Notes:公有云可能不允许 IPIP 流量,例如 Azure
kubernetes 中不管是 flannel
还是 calico
VxLAN 的实现都是使用 Linux 内核功能进行的封装,Linux 对 vxlan 协议的支持时间并不久,2012 年 Stephen Hemminger 才把相关的工作合并到 kernel 中,并最终出现在 kernel 3.7.0 版本。为了稳定性和很多的功能,你可以会看到某些软件推荐在 3.9.0 或者 3.10.0 以后版本的 kernel 上使用 VxLAN
。
A simple VxLAN network topology
在 kubernetes 中 vxlan 网络,例如 flannel
,守护进程会根据 kubernetes 的 Node 而维护 VxLAN
,名称为 flannel.1
这是 VNID
,并维护这个网络的路由,当发生跨节点的流量时,本地会维护对端 VxLAN
设备的 MAC 地址,通过这个地址可以知道发送的目的端,这样就可以封包发送到对端,收到包的对端 VxLAN 设备 flannel.1
解包后得到真实的目的地址。
查看 Forwarding database
列表
$ bridge fdb
26:5e:87:90:91:fc dev flannel.1 dst 10.0.0.3 self permanent
VxLAN in kubernetes
VxLAN packet with wireshark unpack
Notes:VxLAN 使用的 4789 端口,wireshark 应该是根据端口进行分析协议的,而 flannel 在 linux 中默认端口是 8472,此时抓包仅能看到是一个 UDP 包。
通过上述的架构可以看出,隧道实际上是一个抽象的概念,并不是建立的真实的两端的隧道,而是通过将数据包封装成另一个数据包,通过物理设备传输后,经由相同的设备(网络隧道)进行解包实现网络的叠加。
weave 也是使用了 VxLAN
技术完成的包的封装,这个技术在 weave
中称之为 fastdp (fast data path)
,与 calico
和 flannel
中用到的技术不同的,这里使用的是 Linux 内核中的 openvswitch datapath module
,并且 weave 对网络流量进行了加密。
weave fastdp network topology
Notes:fastdp 工作在 Linux 内核版本 3.12 及更高版本,如果低于此版本的例如 CentOS7,weave 将工作在用户空间,weave 中称之为
sleeve mode
https://github.com/flannel-io/flannel/blob/master/Documentation/backends.md#host-gw
https://projectcalico.docs.tigera.io/networking/bgp
https://www.weave.works/docs/net/latest/concepts/router-encapsulation/
https://github.com/k8snetworkplumbingwg/sriov-network-device-plugin
https://github.com/nokia/danm
本文由哈喽比特于2年以前收录,如有侵权请联系我们。
文章来源:https://mp.weixin.qq.com/s/pgXQOak1RbSydTQFNRAdbg
京东创始人刘强东和其妻子章泽天最近成为了互联网舆论关注的焦点。有关他们“移民美国”和在美国购买豪宅的传言在互联网上广泛传播。然而,京东官方通过微博发言人发布的消息澄清了这些传言,称这些言论纯属虚假信息和蓄意捏造。
日前,据博主“@超能数码君老周”爆料,国内三大运营商中国移动、中国电信和中国联通预计将集体采购百万台规模的华为Mate60系列手机。
据报道,荷兰半导体设备公司ASML正看到美国对华遏制政策的负面影响。阿斯麦(ASML)CEO彼得·温宁克在一档电视节目中分享了他对中国大陆问题以及该公司面临的出口管制和保护主义的看法。彼得曾在多个场合表达了他对出口管制以及中荷经济关系的担忧。
今年早些时候,抖音悄然上线了一款名为“青桃”的 App,Slogan 为“看见你的热爱”,根据应用介绍可知,“青桃”是一个属于年轻人的兴趣知识视频平台,由抖音官方出品的中长视频关联版本,整体风格有些类似B站。
日前,威马汽车首席数据官梅松林转发了一份“世界各国地区拥车率排行榜”,同时,他发文表示:中国汽车普及率低于非洲国家尼日利亚,每百户家庭仅17户有车。意大利世界排名第一,每十户中九户有车。
近日,一项新的研究发现,维生素 C 和 E 等抗氧化剂会激活一种机制,刺激癌症肿瘤中新血管的生长,帮助它们生长和扩散。
据媒体援引消息人士报道,苹果公司正在测试使用3D打印技术来生产其智能手表的钢质底盘。消息传出后,3D系统一度大涨超10%,不过截至周三收盘,该股涨幅回落至2%以内。
9月2日,坐拥千万粉丝的网红主播“秀才”账号被封禁,在社交媒体平台上引发热议。平台相关负责人表示,“秀才”账号违反平台相关规定,已封禁。据知情人士透露,秀才近期被举报存在违法行为,这可能是他被封禁的部分原因。据悉,“秀才”年龄39岁,是安徽省亳州市蒙城县人,抖音网红,粉丝数量超1200万。他曾被称为“中老年...
9月3日消息,亚马逊的一些股东,包括持有该公司股票的一家养老基金,日前对亚马逊、其创始人贝索斯和其董事会提起诉讼,指控他们在为 Project Kuiper 卫星星座项目购买发射服务时“违反了信义义务”。
据消息,为推广自家应用,苹果现推出了一个名为“Apps by Apple”的网站,展示了苹果为旗下产品(如 iPhone、iPad、Apple Watch、Mac 和 Apple TV)开发的各种应用程序。
特斯拉本周在美国大幅下调Model S和X售价,引发了该公司一些最坚定支持者的不满。知名特斯拉多头、未来基金(Future Fund)管理合伙人加里·布莱克发帖称,降价是一种“短期麻醉剂”,会让潜在客户等待进一步降价。
据外媒9月2日报道,荷兰半导体设备制造商阿斯麦称,尽管荷兰政府颁布的半导体设备出口管制新规9月正式生效,但该公司已获得在2023年底以前向中国运送受限制芯片制造机器的许可。
近日,根据美国证券交易委员会的文件显示,苹果卫星服务提供商 Globalstar 近期向马斯克旗下的 SpaceX 支付 6400 万美元(约 4.65 亿元人民币)。用于在 2023-2025 年期间,发射卫星,进一步扩展苹果 iPhone 系列的 SOS 卫星服务。
据报道,马斯克旗下社交平台𝕏(推特)日前调整了隐私政策,允许 𝕏 使用用户发布的信息来训练其人工智能(AI)模型。新的隐私政策将于 9 月 29 日生效。新政策规定,𝕏可能会使用所收集到的平台信息和公开可用的信息,来帮助训练 𝕏 的机器学习或人工智能模型。
9月2日,荣耀CEO赵明在采访中谈及华为手机回归时表示,替老同事们高兴,觉得手机行业,由于华为的回归,让竞争充满了更多的可能性和更多的魅力,对行业来说也是件好事。
《自然》30日发表的一篇论文报道了一个名为Swift的人工智能(AI)系统,该系统驾驶无人机的能力可在真实世界中一对一冠军赛里战胜人类对手。
近日,非营利组织纽约真菌学会(NYMS)发出警告,表示亚马逊为代表的电商平台上,充斥着各种AI生成的蘑菇觅食科普书籍,其中存在诸多错误。
社交媒体平台𝕏(原推特)新隐私政策提到:“在您同意的情况下,我们可能出于安全、安保和身份识别目的收集和使用您的生物识别信息。”
2023年德国柏林消费电子展上,各大企业都带来了最新的理念和产品,而高端化、本土化的中国产品正在不断吸引欧洲等国际市场的目光。
罗永浩日前在直播中吐槽苹果即将推出的 iPhone 新品,具体内容为:“以我对我‘子公司’的了解,我认为 iPhone 15 跟 iPhone 14 不会有什么区别的,除了序(列)号变了,这个‘不要脸’的东西,这个‘臭厨子’。