91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Kubernetes中的網(wǎng)絡(luò)模型

jf_TEuU2tls ? 來源:浩道linux ? 作者:浩道linux ? 2022-12-14 10:07 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

前言

Overview

本文將探討 Kubernetes 中的網(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ù)包傳輸。

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

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

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

k8s 中的 underlay network

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

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

這種模型下典型的有flannelhost-gw模式與calicoBGP模式。

flannel host-gw

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

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

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

Calico BGP

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

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

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

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

IPVLAN & MACVLAN

IPVLANMACVLAN是一種網(wǎng)卡虛擬化技術(shù),兩者之間的區(qū)別為,IPVLAN允許一個物理網(wǎng)卡擁有多個 IP 地址,并且所有的虛擬接口用同一個 MAC 地址;而MACVLAN則是相反的,其允許同一個網(wǎng)卡擁有多個 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ò)模型屬于下圖中第二個。

a40ad8da-7b4c-11ed-8abf-dac502259ad0.pngVirtual networking modes: bridging, multiplexing and SR-IOV
  • 虛擬網(wǎng)橋:創(chuàng)建一個虛擬網(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ù)用:使用一個中間網(wǎng)絡(luò)設(shè)備,暴露多個虛擬網(wǎng)卡接口,容器網(wǎng)卡都可以介入這個中間設(shè)備,并通過 MAC/IP 地址來區(qū)分 packet 應(yīng)該發(fā)往哪個容器設(shè)備。
  • 硬件交換,為每個 Pod 分配一個虛擬網(wǎng)卡,這樣一來,Pod 與 Pod 之間的連接關(guān)系就會變得非常清晰,因?yàn)榻跷锢頇C(jī)之間的通信基礎(chǔ)。如今大多數(shù)網(wǎng)卡都支持 SR-IOV 功能,該功能將單一的物理網(wǎng)卡虛擬成多個 VF 接口,每個 VF 接口都有單獨(dú)的虛擬 PCIe 通道,這些虛擬的 PCIe 通道共用物理網(wǎng)卡的 PCIe 通道。

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

multus

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

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

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

  • eth0flannel網(wǎng)絡(luò)插件,也是作為 Pod 的默認(rèn)網(wǎng)絡(luò)
  • VF 是主機(jī)的物理端口ens2f0的實(shí)例化。這是英特爾 X710-DA4 上的一個端口。在 Pod 端的 VF 接口名稱為south0。
  • 這個 VF 使用了 DPDK 驅(qū)動程序,此 VF 是從主機(jī)的物理端口ens2f1實(shí)例化出的。這個是英特爾 X710-DA4 上另外一個端口。Pod 內(nèi)的 VF 接口名稱為north0。該接口綁定到 DPDK 驅(qū)動程序vfio-pci。
a4216410-7b4c-11ed-8abf-dac502259ad0.pngMutus networking Architecture overlay and SR-IOV

Notes:術(shù)語

  • 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 共享一個物理資源。
  • PF:PCIe Physical Function,擁有完全控制 PCIe 資源的能力
  • DPDK:Data Plane Development Kit

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

a4335be8-7b4c-11ed-8abf-dac502259ad0.pngMutus 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)一個網(wǎng)絡(luò)到另一個網(wǎng)絡(luò)中的傳輸,具體來說隧道協(xié)議關(guān)注的是數(shù)據(jù)包(幀)。

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

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

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

這種工作在overlay模型下典型的有flannelcalico中的的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加載。

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

Kubernetes 中IPIPVxLAN類似,也是通過網(wǎng)絡(luò)隧道技術(shù)實(shí)現(xiàn)的。與VxLAN差別就是,VxLAN本質(zhì)上是一個 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 的實(shí)現(xiàn)都是使用 Linux 內(nèi)核功能進(jìn)行的封裝,Linux 對 vxlan 協(xié)議的支持時間并不久,2012 年 Stephen Hemminger 才把相關(guān)的工作合并到 kernel 中,并最終出現(xiàn)在 kernel 3.7.0 版本。為了穩(wěn)定性和很多的功能,你可以會看到某些軟件推薦在 3.9.0 或者 3.10.0 以后版本的 kernel 上使用VxLAN。

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

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

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

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

weave vxlan

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

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

Notes:fastdp 工作在 Linux 內(nèi)核版本 3.12 及更高版本,如果低于此版本的例如 CentOS7,weave 將工作在用戶空間,weave 中稱之為sleeve mode


審核編輯 :李倩


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 以太網(wǎng)
    +關(guān)注

    關(guān)注

    41

    文章

    5995

    瀏覽量

    180771
  • Linux
    +關(guān)注

    關(guān)注

    88

    文章

    11756

    瀏覽量

    218997

原文標(biāo)題:【硬核系列】看看人家圖解K8S網(wǎng)絡(luò),那叫通透易懂!

文章出處:【微信號:浩道linux,微信公眾號:浩道linux】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    KubePi:開源Kubernetes可視化管理面板,讓集群管理如此簡單

    同集群(Cluster)和命名空間(Namespace)的管理權(quán)限分配給指定用戶。這意味著: 開發(fā)人員 :可以管理集群運(yùn)行的應(yīng)用程序并進(jìn)行故障排查,而無需深入掌握復(fù)雜的Kubernetes命令。 運(yùn)
    發(fā)表于 02-11 12:53

    Kubernetes kubectl命令行工具詳解

    kubectl是Kubernetes官方提供的命令行工具,作為與Kubernetes集群交互的主要接口,它通過調(diào)用Kubernetes API Server實(shí)現(xiàn)對集群資源的全面管理。在生產(chǎn)環(huán)境
    的頭像 發(fā)表于 02-02 16:40 ?406次閱讀

    構(gòu)建CNN網(wǎng)絡(luò)模型并優(yōu)化的一般化建議

    整個模型非常巨大。所以要想實(shí)現(xiàn)輕量級的CNN神經(jīng)網(wǎng)絡(luò)模型,首先應(yīng)該避免嘗試單層神經(jīng)網(wǎng)絡(luò)。 2)減少卷積核的大小:CNN神經(jīng)網(wǎng)絡(luò)是通過權(quán)值共
    發(fā)表于 10-28 08:02

    在Ubuntu20.04系統(tǒng)訓(xùn)練神經(jīng)網(wǎng)絡(luò)模型的一些經(jīng)驗(yàn)

    本帖欲分享在Ubuntu20.04系統(tǒng)訓(xùn)練神經(jīng)網(wǎng)絡(luò)模型的一些經(jīng)驗(yàn)。我們采用jupyter notebook作為開發(fā)IDE,以TensorFlow2為訓(xùn)練框架,目標(biāo)是訓(xùn)練一個手寫數(shù)字識別的神經(jīng)
    發(fā)表于 10-22 07:03

    香港服務(wù)器支持Docker和Kubernetes嗎?

    Kubernetes的部署與運(yùn)行? 答案是肯定的,而且香港服務(wù)器由于其獨(dú)特的優(yōu)勢,往往是部署容器化應(yīng)用的絕佳選擇。 下面,我們將從技術(shù)支持、網(wǎng)絡(luò)優(yōu)勢、實(shí)踐指南和注意事項(xiàng)等方面,全面解析香港服務(wù)器與云原生技術(shù)的完美契合度。 一、核心技術(shù)支持:堅(jiān)如磐石的基
    的頭像 發(fā)表于 10-21 15:47 ?675次閱讀

    Kubernetes安全加固的核心技術(shù)

    在生產(chǎn)環(huán)境,Kubernetes集群的安全性直接關(guān)系到企業(yè)數(shù)據(jù)安全和業(yè)務(wù)穩(wěn)定性。本文將從實(shí)戰(zhàn)角度,帶你掌握K8s安全加固的核心技術(shù)。
    的頭像 發(fā)表于 08-18 11:18 ?798次閱讀

    高效管理Kubernetes集群的實(shí)用技巧

    作為一名經(jīng)驗(yàn)豐富的運(yùn)維工程師,我深知在日常的Kubernetes集群管理,熟練掌握kubectl命令是提升工作效率的關(guān)鍵。今天,我將分享15個經(jīng)過實(shí)戰(zhàn)檢驗(yàn)的kubectl實(shí)用技巧,幫助你像藝術(shù)家一樣優(yōu)雅地管理K8s集群。
    的頭像 發(fā)表于 08-13 15:57 ?916次閱讀

    Kubernetes網(wǎng)絡(luò)模型詳解

    如果你也遇到過這些問題,恭喜你找對地方了。今天我將毫無保留地分享K8s網(wǎng)絡(luò)的核心原理和實(shí)戰(zhàn)經(jīng)驗(yàn)。
    的頭像 發(fā)表于 08-13 15:52 ?739次閱讀

    基于eBPF的Kubernetes網(wǎng)絡(luò)異常檢測系統(tǒng)

    作為一名在云原生領(lǐng)域深耕多年的運(yùn)維工程師,我見過太多因?yàn)?b class='flag-5'>網(wǎng)絡(luò)問題導(dǎo)致的生產(chǎn)事故。傳統(tǒng)的監(jiān)控手段往往是事后諸葛亮,當(dāng)你發(fā)現(xiàn)問題時,用戶已經(jīng)在抱怨了。今天,我將分享如何利用 eBPF 這一革命性技術(shù),構(gòu)建一套能夠?qū)崟r檢測 Kubernetes
    的頭像 發(fā)表于 07-24 14:09 ?720次閱讀

    生產(chǎn)環(huán)境Kubernetes容器安全的最佳實(shí)踐

    隨著容器化技術(shù)的快速發(fā)展,Kubernetes已成為企業(yè)級容器編排的首選平臺。然而,在享受Kubernetes帶來的便利性和可擴(kuò)展性的同時,安全問題也日益凸顯。本文將從運(yùn)維工程師的角度,深入探討生產(chǎn)環(huán)境
    的頭像 發(fā)表于 07-14 11:09 ?730次閱讀

    k8s網(wǎng)絡(luò)的基本介紹

    Kubernetes網(wǎng)絡(luò)是指在Kubernetes集群不同組件之間進(jìn)行通信和交互的網(wǎng)絡(luò)架構(gòu)。
    的頭像 發(fā)表于 06-16 13:42 ?938次閱讀

    詳解Kubernetes的Pod調(diào)度親和性

    Kubernetes(K8s),Pod 調(diào)度親和性(Affinity) 是一種高級調(diào)度策略,用于控制 Pod 與節(jié)點(diǎn)(Node)或其他 Pod 之間的關(guān)聯(lián)(親和)或反關(guān)聯(lián)(反親和)關(guān)系。通過親和性規(guī)則,管理員可以更精細(xì)地控制 Pod 的調(diào)度行為,滿足業(yè)務(wù)的拓?fù)浼s束、
    的頭像 發(fā)表于 06-07 13:56 ?929次閱讀

    Kubernetes Helm入門指南

    環(huán)境中部署和管理復(fù)雜應(yīng)用的挑戰(zhàn)。Helm命令行客戶端工具,主要用于Kubernetes應(yīng)用的Chart的創(chuàng)建、打包、發(fā)布和管理。
    的頭像 發(fā)表于 04-30 13:42 ?3079次閱讀
    <b class='flag-5'>Kubernetes</b> Helm入門指南

    Kubernetes中部署MySQL集群

    一般情況下 Kubernetes 可以通過 ReplicaSet 以一個 Pod 模板創(chuàng)建多個 pod 副本,但是它們都是無狀態(tài)的,任何時候它們都可以被一個全新的 pod 替換。
    的頭像 發(fā)表于 03-18 16:22 ?784次閱讀
    <b class='flag-5'>Kubernetes</b>中部署MySQL集群

    Kubernetes包管理工具Helm的安裝和使用

    Helm 可以幫助我們管理 Kubernetes 應(yīng)用程序 - Helm Charts 可以定義、安裝和升級復(fù)雜的 Kubernetes 應(yīng)用程序,Charts 包很容易創(chuàng)建、版本管理、分享和分布。
    的頭像 發(fā)表于 03-13 16:06 ?2181次閱讀