亚洲视频二区_亚洲欧洲日本天天堂在线观看_日韩一区二区在线观看_中文字幕不卡一区

公告:魔扣目錄網(wǎng)為廣大站長提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請做好本站友鏈:【 網(wǎng)站目錄:http://www.430618.com 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

如果本文對你有幫助,歡迎關(guān)注、點(diǎn)贊、收藏、轉(zhuǎn)發(fā)給朋友,讓我有持續(xù)創(chuàng)作的動(dòng)力

Overview

本文將探討kube.NETes中的網(wǎng)絡(luò)模型,以及對各種網(wǎng)絡(luò)模型進(jìn)行分析。

Underlay Network Model

什么是Underlay Network

底層網(wǎng)絡(luò) Underlay Network 顧名思義是指網(wǎng)絡(luò)設(shè)備基礎(chǔ)設(shè)施,如交換機(jī),路由器, DWDM 使用網(wǎng)絡(luò)介質(zhì)將其鏈接成的物理網(wǎng)絡(luò)拓?fù)洌?fù)責(zé)網(wǎng)絡(luò)之間的數(shù)據(jù)包傳輸。


 

圖:Underlay network topology

underlay network 可以是二層,也可以是三層;二層 underlay network 的典型例子是以太網(wǎng) Ethernet,三層是 underlay network 的典型例子是互聯(lián)網(wǎng) Internet。

而工作與二層的技術(shù)是 vlan,工作在三層的技術(shù)是由OSPF, BGP等協(xié)議組成

kubernetes中的underlay network

在kubernetes中,underlay network 中比較典型的例子是通過將宿主機(jī)作為路由器設(shè)備,Pod 的網(wǎng)絡(luò)則通過學(xué)習(xí)成路由條目從而實(shí)現(xiàn)跨節(jié)點(diǎn)通訊。


 

圖:underlay network topology in kubernetes

這種模型下典型的有 flannel 的 host-gw 模式與 calico BGP 模式。

flannel host-gw

flannel host-gw 模式中每個(gè)Node需要在同一個(gè)二層網(wǎng)絡(luò)中,并將Node作為一個(gè)路由器,跨節(jié)點(diǎn)通訊將通過路由表方式進(jìn)行,這樣方式下將網(wǎng)絡(luò)模擬成一個(gè)underlay network。


 

圖:layer2 ethernet topology

 

Notes:因?yàn)槭峭ㄟ^路由方式,集群的cidr至少要配置16,因?yàn)檫@樣可以保證,跨節(jié)點(diǎn)的Node作為一層網(wǎng)絡(luò),同節(jié)點(diǎn)的Pod作為一個(gè)網(wǎng)絡(luò)。如果不是這種用情況,路由表處于相同的網(wǎng)絡(luò)中,會(huì)存在網(wǎng)絡(luò)不可達(dá)

 

Calico BGP

BGP(Border Gateway Protocol)是去中心化自治路由協(xié)議。它是通過維護(hù)IP路由表或'前綴'表來實(shí)現(xiàn)AS (Autonomous System)之間的可訪問性,屬于向量路由協(xié)議。


 

圖:BGP network topology

與 flannel 不同的是,Calico 提供了的 BGP 網(wǎng)絡(luò)解決方案,在網(wǎng)絡(luò)模型上,Calico 與 Flannel host-gw 是近似的,但在軟件架構(gòu)的實(shí)現(xiàn)上,flannel 使用 flanneld 進(jìn)程來維護(hù)路由信息;而 Calico 是包含多個(gè)守護(hù)進(jìn)程的,其中 Brid 進(jìn)程是一個(gè) BGP 的客戶端 與路由反射器(Router Reflector),BGP 客戶端負(fù)責(zé)從 Felix 中獲取路由并分發(fā)到其他 BGP Peer,而反射器在BGP中起了優(yōu)化的作用。在同一個(gè)IBGP中,BGP客戶端僅需要和一個(gè) RR 相連,這樣減少了AS內(nèi)部維護(hù)的大量的BGP連接。通常情況下,RR 是真實(shí)的路由設(shè)備,而 Bird 作為 BGP 客戶端工作。


 

圖:Calico Network Architecture

IPVLAN & macVLAN

IPVLAN 和 MACVLAN 是一種網(wǎng)卡虛擬化技術(shù),兩者之間的區(qū)別為, IPVLAN 允許一個(gè)物理網(wǎng)卡擁有多個(gè)IP地址,并且所有的虛擬接口用同一個(gè)MAC地址;而 MACVLAN 則是相反的,其允許同一個(gè)網(wǎng)卡擁有多個(gè)MAC地址,而虛擬出的網(wǎng)卡可以沒有IP地址。

因?yàn)槭蔷W(wǎng)卡虛擬化技術(shù),而不是網(wǎng)絡(luò)虛擬化技術(shù),本質(zhì)上來說屬于 Overlay network,這種方式在虛擬化環(huán)境中與Overlay network 相比最大的特點(diǎn)就是可以將Pod的網(wǎng)絡(luò)拉平到Node網(wǎng)絡(luò)同級,從而提供更高的性能、低延遲的網(wǎng)絡(luò)接口。本質(zhì)上來說其網(wǎng)絡(luò)模型屬于下圖中第二個(gè)。

 

  • 虛擬網(wǎng)橋:創(chuàng)建一個(gè)虛擬網(wǎng)卡對(veth pair),一頭栽容器內(nèi),一頭栽宿主機(jī)的root namespaces內(nèi)。這樣一來容器內(nèi)發(fā)出的數(shù)據(jù)包可以通過網(wǎng)橋直接進(jìn)入宿主機(jī)網(wǎng)絡(luò)棧,而發(fā)往容器的數(shù)據(jù)包也可以經(jīng)過網(wǎng)橋進(jìn)入容器。
  • 多路復(fù)用:使用一個(gè)中間網(wǎng)絡(luò)設(shè)備,暴露多個(gè)虛擬網(wǎng)卡接口,容器網(wǎng)卡都可以介入這個(gè)中間設(shè)備,并通過MAC/IP地址來區(qū)分packet應(yīng)該發(fā)往哪個(gè)容器設(shè)備。

 

硬件交換,為每個(gè)Pod分配一個(gè)虛擬網(wǎng)卡,這樣一來,Pod與Pod之間的連接關(guān)系就會(huì)變得非常清晰,因?yàn)榻跷锢頇C(jī)之間的通信基礎(chǔ)。如今大多數(shù)網(wǎng)卡都支持SR-IOV功能,該功能將單一的物理網(wǎng)卡虛擬成多個(gè)VF接口,每個(gè)VF接口都有單獨(dú)的虛擬PCIe通道,這些虛擬的PCIe通道共用物理網(wǎng)卡的PCIe通道。


 

圖:Virtual networking modes: bridging, multiplexing and SR-IOV

在kubernetes中 IPVLAN 這種網(wǎng)絡(luò)模型下典型的CNI有,multus 與 danm。

multus

multus 是 intel 開源的CNI方案,是由傳統(tǒng)的 cni 與 multus 組成,并且提供了 SR-IOV CNI 插件使 K8s pod 能夠連接到 SR-IOV VF 。這是使用了 IPVLAN/MACVLAN 的功能。

當(dāng)創(chuàng)建新的Pod后,SR-IOV 插件開始工作。配置 VF 將被移動(dòng)到新的 CNI 名稱空間。該插件根據(jù) CNI 配置文件中的 “name” 選項(xiàng)設(shè)置接口名稱。最后將VF狀態(tài)設(shè)置為UP。

下圖是一個(gè) Multus 和 SR-IOV CNI 插件的網(wǎng)絡(luò)環(huán)境,具有三個(gè)接口的 pod。

 

  • eth0 是 flannel 網(wǎng)絡(luò)插件,也是作為Pod的默認(rèn)網(wǎng)絡(luò)
  • VF 是主機(jī)的物理端口 ens2f0 的實(shí)例化。這是英特爾X710-DA4上的一個(gè)端口。在Pod端的 VF 接口名稱為 south0 。
  • 這個(gè)VF使用了 DPDK 驅(qū)動(dòng)程序,此 VF 是從主機(jī)的物理端口 ens2f1 實(shí)例化出的。這個(gè)是英特爾® X710-DA4上另外一個(gè)端口。Pod 內(nèi)的 VF 接口名稱為 north0。該接口綁定到 DPDK 驅(qū)動(dòng)程序 vfio-pci。

 


 

圖:Mutus networking Architecture overlay and SR-IOV

 

Notes:terminology NIC:network interface card,網(wǎng)卡SR-IOV:single root I/O virtualization,硬件實(shí)現(xiàn)的功能,允許各虛擬機(jī)間共享PCIe設(shè)備。VF:Virtual Function,基于PF,與PF或者其他VF共享一個(gè)物理資源。PF:PCIe Physical Function,擁有完全控制PCIe資源的能力DPDK:Data Plane Development Kit

 

于此同時(shí),也可以將主機(jī)接口直接移動(dòng)到Pod的網(wǎng)絡(luò)名稱空間,當(dāng)然這個(gè)接口是必須存在,并且不能是與默認(rèn)網(wǎng)絡(luò)使用同一個(gè)接口。這種情況下,在普通網(wǎng)卡的環(huán)境中,就直接將Pod網(wǎng)絡(luò)與Node網(wǎng)絡(luò)處于同一個(gè)平面內(nèi)了。


 

圖:Mutus networking Architecture overlay and ipvlan

danm

DANM是諾基亞開源的CNI項(xiàng)目,目的是將電信級網(wǎng)絡(luò)引入kubernetes中,與multus相同的是,也提供了SR-IOV/DPDK 的硬件技術(shù),并且支持IPVLAN.

Overlay Network Model

什么是Overlay

疊加網(wǎng)絡(luò)是使用網(wǎng)絡(luò)虛擬化技術(shù),在 underlay 網(wǎng)絡(luò)上構(gòu)建出的虛擬邏輯網(wǎng)絡(luò),而無需對物理網(wǎng)絡(luò)架構(gòu)進(jìn)行更改。本質(zhì)上來說,overlay network 使用的是一種或多種隧道協(xié)議 (tunneling),通過將數(shù)據(jù)包封裝,實(shí)現(xiàn)一個(gè)網(wǎng)絡(luò)到另一個(gè)網(wǎng)絡(luò)中的傳輸,具體來說隧道協(xié)議關(guān)注的是數(shù)據(jù)包(幀)。


 

圖:overlay network topology

常見的網(wǎng)絡(luò)隧道技術(shù)

 

  • 通用路由封裝 ( Generic Routing Encapsulation ) 用于將來自 IPv4/IPv6的數(shù)據(jù)包封裝為另一個(gè)協(xié)議的數(shù)據(jù)包中,通常工作與L3網(wǎng)絡(luò)層中。
  • VxLAN (Virtual Extensible LAN),是一個(gè)簡單的隧道協(xié)議,本質(zhì)上是將L2的以太網(wǎng)幀封裝為L4中UDP數(shù)據(jù)包的方法,使用 4789 作為默認(rèn)端口。VxLAN 也是 VLAN 的擴(kuò)展對于 4096( 位 VLAN ID) 擴(kuò)展為1600萬( 位 VNID )個(gè)邏輯網(wǎng)絡(luò)。

 

這種工作在 overlay 模型下典型的有 flannel 與 calico 中的的 VxLAN, IPIP 模式。

IPIP

IP in IP 也是一種隧道協(xié)議,與 VxLAN 類似的是,IPIP 的實(shí)現(xiàn)也是通過linux內(nèi)核功能進(jìn)行的封裝。IPIP 需要內(nèi)核模塊 ipip.ko 使用命令查看內(nèi)核是否加載IPIP模塊lsmod | grep ipip ;使用命令modprobe ipip 加載。


 

圖:A simple IPIP network workflow

Kubernetes中 IPIP 與 VxLAN 類似,也是通過網(wǎng)絡(luò)隧道技術(shù)實(shí)現(xiàn)的。與 VxLAN 差別就是,VxLAN 本質(zhì)上是一個(gè) UDP包,而 IPIP 則是將包封裝在本身的報(bào)文包上。


 

圖:IPIP in kubernetes


 

圖:IPIP packet with wireshark unpack

 

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

 

VxLAN

kubernetes中不管是 flannel 還是 calico VxLAN的實(shí)現(xiàn)都是使用Linux內(nèi)核功能進(jìn)行的封裝,Linux 對 vxlan 協(xié)議的支持時(shí)間并不久,2012 年 Stephen Hemminger 才把相關(guān)的工作合并到 kernel 中,并最終出現(xiàn)在 kernel 3.7.0 版本。為了穩(wěn)定性和很多的功能,你可以會(huì)看到某些軟件推薦在 3.9.0 或者 3.10.0 以后版本的 kernel 上使用 VxLAN。


 

圖:A simple VxLAN network topology

在kubernetes中vxlan網(wǎng)絡(luò),例如 flannel,守護(hù)進(jìn)程會(huì)根據(jù)kubernetes的Node而維護(hù) VxLAN,名稱為 flannel.1 這是 VNID,并維護(hù)這個(gè)網(wǎng)絡(luò)的路由,當(dāng)發(fā)生跨節(jié)點(diǎn)的流量時(shí),本地會(huì)維護(hù)對端 VxLAN 設(shè)備的MAC地址,通過這個(gè)地址可以知道發(fā)送的目的端,這樣就可以封包發(fā)送到對端,收到包的對端 VxLAN設(shè)備 flannel.1 解包后得到真實(shí)的目的地址。

查看 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應(yīng)該是根據(jù)端口進(jìn)行分析協(xié)議的,而flannel在linux中默認(rèn)端口是8472,此時(shí)抓包僅能看到是一個(gè)UDP包。

 

通過上述的架構(gòu)可以看出,隧道實(shí)際上是一個(gè)抽象的概念,并不是建立的真實(shí)的兩端的隧道,而是通過將數(shù)據(jù)包封裝成另一個(gè)數(shù)據(jù)包,通過物理設(shè)備傳輸后,經(jīng)由相同的設(shè)備(網(wǎng)絡(luò)隧道)進(jìn)行解包實(shí)現(xiàn)網(wǎng)絡(luò)的疊加。

weave vxlan

weave也是使用了 VxLAN 技術(shù)完成的包的封裝,這個(gè)技術(shù)在 weave 中稱之為 fastdp (fast data path),與 calico 和 flannel 中用到的技術(shù)不同的,這里使用的是 Linux 內(nèi)核中的 openvswitch datapath module,并且weave對網(wǎng)絡(luò)流量進(jìn)行了加密。


 

圖:weave fastdp network topology

分享到:
標(biāo)簽:Kubernetes
用戶無頭像

網(wǎng)友整理

注冊時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊賬號,推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績評定2018-06-03

通用課目體育訓(xùn)練成績評定