在K8S中,flannel有几个工作模式及fannel的底层原理如何实现?

news/2025/2/11 21:56:47/文章来源:https://www.cnblogs.com/huangjiabobk/p/18710552

Flannel 是 Kubernetes 中常用的网络插件,用于实现 Pod 之间的跨节点通信。它支持多种工作模式,每种模式都有其特点和适用场景。以下是 Flannel 的主要工作模式及其底层原理:

1. Flannel 的工作模式

Flannel 支持以下几种工作模式:

1.1 VXLAN 模式

VXLAN(Virtual Extensible LAN)模式是 Flannel 的默认模式,也是最常用的模式。它通过封装数据包来实现跨节点通信,具体工作原理如下:

  1. Pod 发起通信:源 Pod 向目标 Pod 发送数据包,数据包首先到达源节点的 cni0 网桥。
  2. 查找目标节点:Flannel 根据目标 Pod 的 IP 地址,查询到目标节点的物理 IP 地址。
  3. 数据封装:Flannel 使用 VXLAN 协议将原始数据包封装在 UDP 报文中,并通过底层网络发送到目标节点。
  4. 解封装数据包:目标节点的 Flannel 接收到封装的数据包后,解封装并还原为原始数据包。
  5. 目标 Pod 接收数据:解封装后的数据包通过目标节点的 cni0 网桥,最终传递给目标 Pod。

VXLAN 模式适用于复杂的网络环境,例如节点跨子网或跨机房的场景。

1.2 Host-GW 模式

Host-GW(Host Gateway)模式基于路由表实现,不需要数据封装,性能更高,但依赖底层网络的路由能力。其工作原理如下:

  1. Pod 发起通信:数据包从源 Pod 发出,进入源节点的 cni0 网桥。
  2. 路由查找:源节点的内核路由表中,Flannel 组件已将目标节点的子网指向目标节点的物理 IP 地址。
  3. 直接转发数据包:数据包直接通过底层物理网络发送到目标节点。
  4. 路由到目标 Pod:目标节点的路由表将数据包转发到其 cni0 网桥,最终传递给目标 Pod。

Host-GW 模式适用于节点位于同一二层网络,且对网络性能要求较高的场景。

1.3 UDP 模式(已废弃)

UDP 模式是 Flannel 最早支持的模式,但性能较差,已被废弃。它通过在用户态对数据包进行封装和解封装来实现跨节点通信。

2. Flannel 的底层原理

Flannel 的核心功能是为 Kubernetes 集群中的每个 Pod 分配一个唯一的 IP 地址,并确保 Pod 之间可以无缝通信。其底层原理主要包括以下几个方面:

2.1 子网分配

Flannel 为每个节点分配一个唯一的子网(例如 10.244.1.0/24),Pod 创建时会从该子网中分配一个 IP 地址。

2.2 数据封装与转发
  • VXLAN 模式:使用 VXLAN 协议将数据包封装在 UDP 报文中,通过虚拟隧道发送到目标节点。
  • Host-GW 模式:通过内核路由表直接转发数据包,无需封装。
2.3 路由规则

Flannel 在每个节点上设置路由规则,确保跨节点的流量可以正确路由到目标 Pod。这些路由规则存储在 etcd 中,并由 Flannel 动态维护。

3. 适用场景
  • VXLAN 模式:适用于节点跨子网或跨机房的复杂网络环境。
  • Host-GW 模式:适用于节点位于同一二层网络,且对网络性能要求较高的场景。

综上所述,通过选择合适的模式,Flannel 可以在不同的网络环境中高效地实现 Pod 之间的通信。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/882270.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ARC191 192 题解

ARC191 题解 A - Replace Digits简要题意给定一个长为 \(n\) 的字符串 \(a\)。\(m\) 次操作,第 \(k\) 次给定一个字符 \(b_k\),你需要选择一个 \(i \in [1, n]\) 并将 \(a_i\) 替换成 \(b_k\)。 求最后能得到的所有字符串中,字典序最大的是什么。 \(1 \leq n, m \leq 10^6\)…

最近,测试的招聘市场已经疯掉了…

这是我入行测试的第1007天,门槛低,技术难度不高,食物链最底端。出现严重的bug,首先背锅的就是测试...📝 博主首页 : 「码上生花」 ,同名公众号 :「伤心的辣条」📝 面试求职: 「面试试题小程序」 ,内容涵盖 测试基础、Linux操作系统、MySQL数据库、Web功能测试、接口…

P1083 [NOIP 2012 提高组] 借教室(差分)

说实话竟然没想到还能这样差分,这道题我们需要二分查找m个订单,对于每次二分用一次差分,然后看如果只考虑1到mid个订单是否会出现教室不够用的情况,如果够用说明导致教室不够用的订单在后面,应该让begin=mid+1;反之让end-1;其实这道题就是让我们找第一个出现教室不够用的…

来吃糖

先放犯错后 be like:1 return // 倍增求 lca int bfs(int x) {queue<int> q;q.push(x);dep[x] = 1;while (q.size()) {x = q.front(), q.pop();for (auto it : G[x]) {int y = it.first, z = it.second;if (dep[y]) continue;dep[y] = dep[x] + 1;d[0][y] = z;f[0][y] =…

P9330 [JOISC 2023] JOI 国的节日 2 题解

Description 对于以下问题:给定长度为 \(n\) 的序列 \(a\)、\(b\),满足以下条件:在序列 \(a\) 与序列 \(b\) 中,\(1\) 到 \(2n\) 的整数各出现恰好一次; 对于 \(1\leq i\leq n\),\(a_i<b_i\); 对于 \(1\leq i<n\),\(a_i<a_{i+1}\)。求:最多能在 \([a_i,b_i]\…

一站式合同自动化:飞书审批与腾讯电子签的完美融合

Z国际教育中心专注于将全球顶尖教育资源引入中国,通过本地化整合与优化,将这些优质资源转化为中国青年触手可及的学习机会。我们的使命是帮助学生培养深厚的家国情怀与开阔的国际视野,助力他们成长为未来社会的栋梁之才。 遇到的问题 1. 业务种类多,合同审批繁琐 通过飞书平…

Linux下Docker及Nvidia Container ToolKit安装教程

作者:SkyXZ CSDN:SkyXZ~-CSDN博客 博客园:SkyXZ - 博客园 我们接下来在Ubuntu中安装Docker(安装详见:Get Docker | Docker Docs)及NVIDIA Container Toolkit(安装详见:Installing the NVIDIA Container Toolkit — NVIDIA Container Toolkit 1.17.3 documentat…

在用 uni-app 开发钉钉小程序的时候遇到一个奇怪的问题,发送请求拿不到返回的数据

今天我一位同事说用 uni-app 新开发的钉钉小程序里发送请求拿不到返回的数据,看了下发现调试工具的“Network”栏里显示请求是发送成功的,也有返回数据,但是没触发请求的回调函数。 原本用的是 luch-request 这个库发送的请求,后来试了下 uni-app 内置的 uni.request 以及钉…

15. 进程处理

一、什么是进程进程(Process)是正在运行的程序,是操作系统进行资源分配的基本单位。程序是存储在硬盘或内存的一段二进制序列,是静态的,而进程是动态的。每个进程都由自己的地址空间、代码段、数据段以及分配给它的其它系统资源(如文件描述符、网络连接等)。 二、创建子…

我把deepseek等大模型接入了微信公众号,打造个人AI助手

我把deepseek等大模型接入了微信公众号,打造个人AI助手前言 最近deepseek大模型可是火出了圈,给国产大模型公司点赞。于是乎去deepseek试了一下效果,奈何太多人使用了,问两句来一句 “服务器繁忙,请稍后再试”,体验感实在太差了。 作为程序员,怎么能忍受?于是乎去寻找d…

(未解决)word中插入pdf图片(高清、矢量图)

(未解决)word中插入pdf图片(高清、矢量图) 1.个人诉求: pdf高清矢量格式的图片,插入至word中 2.尝试的解决方法: https://blog.csdn.net/weixin_45399376/article/details/115281547?spm=1001.2014.3001.5502。 3.具体操作步骤: 1)word——插入——对象——文件中的文…

一语总结

一语总结 真心建议把找到的一些性质和做法以文字形式写下来,当掉不过样例的时候一个一个检查其正确性。”P9169 [省选联考 2023] 过河卒“用DFS将环当作平局是错误的因为这可能只是一个不优的必胜/必败局面,正确的做法是老实建图按拓扑序跑BFS。就这个结论的错误害我虚空调题…