范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文

15张图超硬核讲解Kubernetes网络,我不信网工不会看

  如果本文对你有帮助,欢迎关注、点赞、收藏、转发给朋友,让我有持续创作的动力  Overview
  本文将探讨Kubernetes中的网络模型,以及对各种网络模型进行分析。 Underlay Network Model
  什么是Underlay Network
  底层网络  Underlay Network   顾名思义是指网络设备基础设施,如交换机,路由器, DWDM 使用网络介质将其链接成的物理网络拓扑,负责网络之间的数据包传输。
  图:Underlay network topology
  underlay network 可以是二层,也可以是三层;二层 underlay network 的典型例子是 以太网 Ethernet  ,三层是 underlay network 的典型例子是互联网 Internet  。
  而工作与二层的技术是  vlan  ,工作在三层的技术是由OSPF, BGP  等协议组成
  kubernetes中的underlay network
  在kubernetes中,underlay network 中比较典型的例子是通过将 宿主机  作为路由器设备,Pod 的网络则通过学习成路由条目从而实现跨节点通讯。
  图:underlay network topology in kubernetes
  这种模型下典型的有 flannel 的  host-gw 模式  与 calico BGP 模式  。
  flannel host-gw
  flannel host-gw 模式中每个Node需要在同一个二层网络中,并将Node作为一个路由器,跨节点通讯将通过路由表方式进行,这样方式下将网络模拟成一个 underlay network  。
  图:layer2 ethernet topology
  Notes:因为是通过路由方式,集群的cidr至少要配置16,因为这样可以保证,跨节点的Node作为一层网络,同节点的Pod作为一个网络。如果不是这种用情况,路由表处于相同的网络中,会存在网络不可达
  Calico BGP
  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 和 MACVLAN 是一种网卡虚拟化技术,两者之间的区别为, IPVLAN 允许一个物理网卡拥有多个IP地址,并且所有的虚拟接口用同一个MAC地址;而 MACVLAN 则是相反的,其允许同一个网卡拥有多个MAC地址,而虚拟出的网卡可以没有IP地址。
  因为是网卡虚拟化技术,而不是网络虚拟化技术,本质上来说属于 Overlay network,这种方式在虚拟化环境中与Overlay network 相比最大的特点就是可以将Pod的网络拉平到Node网络同级,从而提供更高的性能、低延迟的网络接口。本质上来说其网络模型属于下图中第二个。 虚拟网桥:创建一个 虚拟网卡对  (veth pair),一头栽容器内,一头栽宿主机的root namespaces内。这样一来容器内发出的数据包可以通过网桥直接进入宿主机网络栈,而发往容器的数据包也可以经过网桥进入容器。多路复用:使用一个中间网络设备,暴露多个虚拟网卡接口,容器网卡都可以介入这个中间设备,并通过MAC/IP地址来区分packet应该发往哪个容器设备。
  硬件交换,为每个Pod分配一个虚拟网卡,这样一来,Pod与Pod之间的连接关系就会变得非常清晰,因为近乎物理机之间的通信基础。如今大多数网卡都支持SR-IOV功能,该功能将单一的物理网卡虚拟成多个VF接口,每个VF接口都有单独的虚拟PCIe通道,这些虚拟的PCIe通道共用物理网卡的PCIe通道。
  图:Virtual networking modes: bridging, multiplexing and SR-IOV
  在kubernetes中 IPVLAN 这种网络模型下典型的CNI有,multus 与 danm。
  multus
  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的默认网络 VF 是主机的物理端口 ens2f0 的实例化。这是英特尔X710-DA4上的一个端口。在Pod端的 VF 接口名称为 south0 。 这个VF使用了 DPDK 驱动程序,此 VF 是从主机的物理端口 ens2f1 实例化出的。这个是英特尔® X710-DA4上另外一个端口。Pod 内的 VF 接口名称为 north0。该接口绑定到 DPDK 驱动程序 vfio-pci。
  图:Mutus networking Architecture overlay and SR-IOV Notes:terminology
  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
  DANM是诺基亚开源的CNI项目,目的是将电信级网络引入kubernetes中,与multus相同的是,也提供了SR-IOV/DPDK 的硬件技术,并且支持IPVLAN. Overlay Network Model
  什么是Overlay
  叠加网络是使用网络虚拟化技术,在 underlay 网络上构建出的虚拟逻辑网络,而无需对物理网络架构进行更改。本质上来说,overlay network 使用的是一种或多种隧道协议 (tunneling),通过将数据包封装,实现一个网络到另一个网络中的传输,具体来说隧道协议关注的是数据包(帧)。
  图:overlay network topology
  常见的网络隧道技术  通用路由封装 ( Generic Routing Encapsulation ) 用于将来自 IPv4/IPv6的数据包封装为另一个协议的数据包中,通常工作与L3网络层中。 VxLAN (Virtual Extensible LAN),是一个简单的隧道协议,本质上是将L2的以太网帧封装为L4中UDP数据包的方法,使用 4789 作为默认端口。VxLAN 也是 VLAN 的扩展对于 4096( 位 VLAN ID) 扩展为1600万( 位 VNID )个逻辑网络。
  这种工作在 overlay 模型下典型的有 flannel 与 calico 中的的 VxLAN, IPIP 模式。
  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
  VxLAN
  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 列表 nbsp;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也是使用了 VxLAN 技术完成的包的封装,这个技术在 weave 中称之为 fastdp (fast data path),与 calico 和 flannel 中用到的技术不同的,这里使用的是 Linux 内核中的 openvswitch datapath module,并且weave对网络流量进行了加密。
  图:weave fastdp network topology

被姐姐踩在脚下的乙男游戏,奇点时代这种宠爱实在不喜欢没想到,一款才刚拿版号还未在国内铺开宣发的游戏,提前因游戏剧情争议火了。这款游戏名为奇点时代,定位男性向恋爱模拟手游,最近,这款游戏在国内市场开启了小范围测试。测试期间,有玩家发现原子之心双生舞伶扮演者俄罗斯芭蕾舞蹈家Cos了自己原子之心这个游戏大家基本上都知道了,这款由Mundfish工作室开发的一款带有恐怖元素的苏式暴力美学第一人称射击游戏基本上是最近话题度最高的游戏了,还获得了玩家投票的2月XGP最佳手游真锁链战记宣布将于5月31日关服世嘉宣布,其运营的手机游戏真锁链战记(SinChronicle)将于日本时间5月31日1130结束服务。这款角色扮演手游最早于2022年3月23日在日本发布,登陆了安卓和iOS系统Konami非常清楚粉丝想要更多恶魔城游戏因此不会错过与死亡细胞的联动死亡细胞大型DLC重返恶魔城已上线,科乐美(Konami)恶魔城系列项目负责人TsutomuTaniguchi近日接受IGN采访时透露,Konami知道粉丝们们想要更多的恶魔城,因新车丨这家伙数据挺强!正面装甲250毫米!ChiToSP游戏内大图本文首发于微信公众号坦克零距离,文章转载权限坦克空间站UP为个人专栏文章作者,非官方人员,在头条同步更新文章R系7级银币坦克歼击车各位车长老爷们大家好啊,我是阿纳贝尔丶卡多。此前我大话西游手游超级大佬为跨服,狂砸四百三十万,打造第一毒女!首先看第一张图片的9亿仙玉!然后对这个大话无限仙玉服有想玩的,可以关注小编,私信回复大话剩下的文字可以不用看,看图片和文章结尾即可!超级大佬为跨服,狂砸四百三十万,打造第一毒女,如王者荣耀美女COS王昭君凤凰于飞(谁是你眼中最美的王昭君)cosplay比较狭义的解释是模仿装扮虚拟世界的角色,也被称为角色扮演。由此,在网络上衍生出了新的含义,往往被用来形容假扮某类人的人。先上图,后说话。1朝朝暮暮,只盼与你相见,所以热血江湖手游资讯早知道端游复刻本期小编为您带来热血江湖手游的最新消息,感谢您的支持,热血江湖的官方版本也在等待上线的消息,现在正在进行最终的测试。相信距离正式开服和正式开放也已经不远了,想来不少老铁早就跃跃欲试三代歌王同聚一堂,谁才是时代的眼泪?留赞都不算歌王了?在游戏中有一些武将的技能发动频率十分高,导致一到他的出牌阶段基本上都是他的语音,上一句还没有说完下一句就开始了,玩家们也是给他们起了歌王这样一个响亮的称号。目前三国杀当中歌王大致可春吃这一菜,越吃越护肝!千万别忘记这个步骤春季万物生发,是养肝护肝的关键期。中医认为,青色入肝经。春季多吃绿色蔬菜可以养护肝脏。而在所有的绿色蔬菜中,最不可错过的就是菠菜。春吃菠菜能补肝中医认为,菠菜味甘,性凉,能滋阴润燥李大夫为什么浑身无力吃生姜就好了?跟我学养生,健康又轻松,大家好,我是李大夫。上周有个朋友私信我说李大夫,浑身无力是怎么回事?不管是白天也好,晚上也好,上班也好,不上班也好,整天都是昏昏沉沉的,乏力。我看了一下这位
全新讴歌NSX纯电跑车曝光,有望于2026年全球首发IT之家9月24日消息,讴歌是日本本田汽车旗下的豪华汽车品牌,于1986年3月27日创立,和雷克萨斯英菲尼迪并列为日本三大豪华汽车品牌,是日本车厂在海外创立的第一个豪华汽车品牌。现Rust1。64。0发布异步是亮点每六周发布一次新版本,在每个新版本中,这里都有一个包含一些亮点1Rust现在有一个与异步相关的新特性IntoFuture。。await语法可用于任何实现IntoFuture的东西。TGA年度最佳游戏战神无敌的儿子和带血条的战神老父亲顶着无数玩家的质疑,战神走下了ACT游戏的神坛,踏上了RPG转型之路战神奎托斯也走下了满是欺骗背叛的神坛,回归了家庭的柔情与温暖,破而后立涅槃重生。目录剧情从神话的宏大回归到家庭的小米11成年抛旗舰!小米犯的错,谁来替受害的用户买单?文馆长Zero最近一段时间,小米又双叒叕上热搜了。当然,不是因为小米12SUltra的产品力有多出色,也不是自研的澎湃芯片有什么进展,而是因为大家比较熟悉的旧产品小米11系列。保修罗技联手腾讯的云游戏掌机来了,但真的没啥诚意毫无疑问,SteamDeck是valve近年来可以说是最成功的作品。自从这款掌机发售以来,就一直占据了Steam游戏销量排行榜的高位,并且在全球玩家中重新点燃了掌机热。眼见着val油价调整消息今天9月24号,调整后各地9295汽油柴油售价今天是2022年9月24日星期六,根据以往的经验,目前国内成品油价格调整幅度处于负值运行,但是因为预计下调的幅度很低,所以现在的调整幅度并不能代表此次油价调整结果,我们还得密切关注三消息!赵睿谈球队困难,辽篮管理层有新变动,中国女篮将战美国第一,赵睿谈球队困难日前,来自广东男篮的后卫赵睿接受记者采访中表示,新赛季球队将会面临很多困难,全队上下都需要站出来承担自己的责任。确实如赵睿而言,新赛季的广东队大概率会经历一段磨上市三个月,暴跌70,同城货运第一股崩塌了上市不到三个月,股价崩跌超70,历史罕见。阿里减持,快狗打车股价崩跌屋漏偏逢连夜雨,船迟又遇打头风。今天(9月22日),港交所文件显示,阿里巴巴于9月15日以每股6。3572港元的福建号正在测试,更大的也要来了文肥佬茄子日前,中国最新型航母福建号最新进度终于曝光,距离进入海试可以说是只剩一步之遥。据央视9月23日报道,最新消息显示,福建号目前正在港口进行系泊测试,各项测试项目正在顺利进行原神赛诺池四星确定!3。2新活动汇总,博士实力有点离谱旅行者们好消息来了,就在刚才3。1上半池的四星确定了,分别为早柚,久岐忍加上坎蒂丝,都是进池次数屈指可数的四星,再加上UP的五星还是赛诺和温迪,感觉质量有点离谱,是少数可以放开抽的昔日英雄联盟上单霸主PDD其竞技实力究竟如何?PDD(刘谋),位置上单(早期打过AD)效力战队NGGEHOMEIG,效力时间20112014年。综合评价T2(强)作为孙亚龙同一时期的队友,PDD一直承担队内核心的角色,其综合实