【云原生】Kubernetes网络知识

Kubernetes网络管理

文章目录

  • Kubernetes网络管理
    • 一、案例概述
    • 二、案例前置知识点
      • 2.1、Kubernetes网络模型
      • 2.2、Docker网络基础
      • 2.3、Kubernetes网络通信
        • 2.3.1、Pod内容器与内容之间的通信
        • 2.3.2、Pod与Pod之间的通信
      • 2.4、Flannel网络插件
      • 2.5、Calico网络插件
        • 2.5.1、Calico网络模型工作组件
        • 2.5.2、Calico网络Node之间两种网络

一、案例概述

  • 随着Docker容器化的兴起,云计算面对的挑战越来越大。例如:网络管理、存储等。一个数据中心基本上都有成千个容器,这么多的容器需要运维人员集中管理。而在云计算的世界中,计算是最基础的,存储是最重要的,网络则是最复杂的,。Kubernetes网络的实现不是集群内部自己实现,而是依赖于第三方网络插件。本章主要介绍Kubernetes网络相关知识与Kubernetes网络组件中的一个重要成员——Calico

二、案例前置知识点

2.1、Kubernetes网络模型

  • Kubernetes网络模型设计的基础原则是:每个Pod都拥有一个独立的IP地址,而且假定所有Pod都在一个可以直接连通的、扁平的网络空间中。所以不管它们是否运行在同一个Node(宿主机)中,都要求它们可以直接通过对象的IP地址进行访问。设计这个原则的原因是,用户不需要额外考虑如果建立Pod之间的连接,也不需要考虑讲容器端口映射到主机端口等问题

  • 实际上,在Kubernetes中IP电子hi是以Pod为单位进行分配的。一个Pod内部的所有容器共享一个网络堆栈,实际上就是一个网络命名空间,包括它们的IP地址、网络设备、配置等都是共享的。

Kubernetes对集群网络有如下要求:

  • 所有的容器都可以在不用NAT的方式下同别的容器通讯
  • 所有节点都可以在不用NAT的方式下同所有容器通讯
  • 容器的地址和别人看到的地址是同一个地址

2.2、Docker网络基础

  • Kubernetes网络依赖于Docker,Docker网络又离不开Linux操作系统内核特性的支持。所以学习Kubernetes网络之前,有必要 先了解Docker网络的基础知识。下面针对Docker使用到的与Linux网络有关的主要技术进行简单介绍

  • 网络命名空间:Linux在网络栈中引入网络命名空间,将独立的网络协议栈隔离到不同的命名空间中。处于不同命名空间的网络栈是完全隔离的,彼此之间无法通信。Docker正式利用这一特性,实现了不同容器之间的网络隔离

  • Veth设备对:Veth设备对的引入是为了实现不同网络命名空间之间的通信,利用它可以直接将两个命名空间连接起来。由于要连接两个命名空间,所以Veth设备都是成对出现的

  • 网桥:网络是要给二层网络设备,通过网桥可以将Linux支持若干个网络端口“连接”起来,使得网络节点之间的报文能够相互转发,并实现类似于交换机一样的多对多通信

  • iptables/Netfilter:Netfilter负责在内核中执行各种挂接的规则,运行在内核模式中;iptables是在用户模式下运行的进程,负责协助维护内核中Netfilter的各种规则表。通过二者的配合来实现整个Linux网络协议中灵活的数据包处理机制

  • 路由:Linux系统包含一个完整的路由功能,当IP层在处理数据发送或者转发的时候,会使用路由表来决定发往哪里

2.3、Kubernetes网络通信

在实际的业务应用场景中,业务组件之间的关系十分复杂。特别是随着微服务的不断发展与成熟,应用部署的粒度也更加细小和灵活。为了支持应用组件之间的通信,kubernetes网络通信主要分为以下几种情况

  • Pod内容器与容器之间的通信
  • Pod与Pod之间的通信
  • Pod与Service之间的通信
  • 集群外部与内部组件之间的通信
2.3.1、Pod内容器与内容之间的通信
  • 在同一个Pod内的容器(Pod内的容器时不会跨主机的)共享同一个网络命名空间,所以对于网络的各类操作,就和它们在同一台机器上一样,甚至可以用localhost地址访问彼此的端口。Pod内网络拓扑模型如下所示
    在这里插入图片描述
2.3.2、Pod与Pod之间的通信

Pod与Pod之间的通信分为两种情况:同一个Node内Pod之间的通信、不同Node上Pod之间的通信

  • 同一个Node内Pod之间的通信

每个Pod都有一个真实的全局IP地址,同一个Node内不同Pod之间可以直接采用对方Pod的IP地址进行通信,不需要采用其他发现机制,例如DNS、Consul或者etcd。同一个Node内Pod之间的关系如下图所示。由下图可以得知,Pod1与Pod2都是通过Veth连接到同一个docker0网桥,地址段相同,所以它们之间可以直接通信
在这里插入图片描述

  • 不同Node上Pod之间的通信

Pod地址与docker0在同一个网段,docker0网段与宿主机网卡是两个不同的网段,且不同Node之间的通信只能通过宿主机的物理网卡进行。要想实现不同Node上Pod之间的通信,就必须想办法通过主机的这个IP地址进行寻址和通信。因此不同Node中Pod间通信要满足两个条件:Pod的IP地址不能冲突;将Pod的IP和所在的Node的IP关联起来,通过这个关联让Pod可以相互访问
在这里插入图片描述

  • Pod与Service之间的通信

在kubernetes中Pod的IP地址并不是固定的每当应用程序按比例放大或者缩小,或遇到错误并需要重新启动时,其IP地址将消失并需要重新分配。因此kubernetes引进了Service的感念

Service是一个抽象的实体,kubernetes在创建Service时,会为其分配一个虚拟IP地址。当外界需要访问Pod里的容器提供的功能时,不直接访问Pod的IP地址和端口,而是访问Service的虚拟IP地址和端口,由Service把请求转发给它背后的Pod,kubernetes在创建Service时,根据Service的标签选择器来查找Pod,据此创建与Service同名的EndPoints对象。当Pod的地址发生变化时,EndPoints也随之变化。Service接收到请求时,就能通过EndPoints找到对应的Pod

当然Service只是一个虚拟的概念,真正完成请求转发的是运行在Node节点上的kube-proxy。Service的虚拟IP就是由kube-proxy实现的。kube-proxy有两种请求转发模式:userspace模式和iptables模式

  • 集群外部与内部组件之间的通信

ClusterIP类型:这种类型的Service只会得到虚拟的IP和端口,只能在kubernetes集群内部被访问,此模型是默认类型

NodePort类型:这种类型的Service除了会得到虚拟的IP和端口,kubernetes还会在所有Node节点上为其分配端口。分配的端口的值可以通过spec.ports[*].nodePort指定,或由kubernetes在配置好的区间里分配(默认为30000-32767).这种Service既可以从kubernetes集群通过虚拟IP:端口访问,也可以从集群外部通过Node节点的IP:nodePort访问

LoadBalancer类型:这种类型的Service除了会得到虚拟的IP和端口,kubernetes还会再所有Node节点上为其分配端口,然后为其开通负载均衡。这种Service既可以从kubernetes集群通过虚拟IP:端口访问,也可以从集群外部通过Node节点的IP:nodePort访问,还可以通过负载均衡的IP访问

  • K8S网络的实现不是集群内部自己实现,而是依赖于第三方网络插件——CNI,例如Flannel、Calico等

2.4、Flannel网络插件

  • Flannel是CoreOS团段针对kubernetes设置的一个网络规划服务。简单来说,它的功能让集群中的不同节点主机创建的Docker容器都具有全集群唯一的虚拟IP地址。在默认的Docker配置中,每个节点上的Docker服务会分别负责所在节点容器的IP分配。这样导致的问题是,不同节点上容器可能获得相同的内外IP地址

  • Flannel的设计目的就是为了集群中的所有节点重新规划IP地址的使用规划,从而使得不同节点上的容器能够获得“同属于一个内网”且不重复的IP地址,并让属于不同节点上的容器能够直接通过内网IP地址通信

  • Flannel实质上是一个“覆盖网络(overlay network)”,也就是将TCP数据包装在另一中网络包里面进行路由转发和通信,目前已经支持UDP、VxLAN、AWS VPC和GCE路由等数据转发方式,默认的节点间数据通信方式是UDP转发。Flannel具体工作原理如下图所示
    在这里插入图片描述

  • 数据从源容器中发出后,经由所在主机的docker0虚拟网卡转发到faanel0虚拟网卡,这是个P2P的虚拟网卡,flanneld服务监听的网卡另外一段

  • Flannel通过Etcd服务维护了以后一张节点间的路由表。源主机的flanneld服务将原本的数据内容UDP封装后根据自己的路由表投递给目的节点的flanneld服务,数据到达以后被解包,然后直接进入母的节点的flannel0虚拟网卡,之后被转发目的主机的docker0虚拟网卡,最后就像本机容器通信一下的有docker0路由到达目标容器

2.5、Calico网络插件

  • Calico是一种基于BGP的、纯三层的、容器间互通的网络方案。与Openstack、kubernetes、AWS、GCE等云平台都能够良好的集成。在虚拟话平台中,如Open stack、Docker等都需要实现workloads之间互联,但同时也需要对容器作隔离控制,就像在internet中的服务仅开放80端口、共有元的多租户一样,提供隔离和管控机制
  • 而在多数的虚拟化平台实现中,通常使用二层隔离技术来实现容器的网络,这些二层技术有一些弊端,比如需要依赖VLAN、bridge和隧道技术。其中bridge带来了复杂性,vlan隔离和tunnel隧道则消耗更多的资源并对物理环境有要求,随着网络规模的增大,整体会变得越加复杂。我们尝试把Host当作internet中的路由器,同样使用BGP同步路由并使用iptables来做安全访问策略,最终设计出了calico方案
    在这里插入图片描述
2.5.1、Calico网络模型工作组件
  • Felix:运行在每一台Host的agent进程,主要负责网络接口管理和监听、路由、ARP管理、ACL管理和同步、状态上报等
  • etcd:分布式键值存储,主要负责网络元数据的一致性,确Calic网络状态的准确性,可以与kubernetes公用
  • VGP Client(BIRD):Calico为每一台Host部署一个BGP Client,使用BIRD实现。BIRD是一个单独的持续发展的项目,实现了众多动态路由协议比如VGP、OSPF、RIP等。在Calico的角色是监听Host上由Felix注入的路由信息,然后通过BGP协议广播告诉剩余Host节点,从而实现网络互通
  • BGP Route Reflector:在大型网络规模中,如果仅仅使用BGP client形成mesh全网互联的方案就会导致规模限制,因为所有节点之间俩俩相连,需要N^2个连接,为了解决这个规模问题,可以采用BGP的Route Reflector的方法,使所有BGP client仅与特定RR节点互联并路由同步,从而大大介绍连接数
  • CalicoCtl:Calico命令行工具
2.5.2、Calico网络Node之间两种网络
  • IPIP

从字面来理解,就是把一个IP数据包又套在一个IP包里,即把IP封装到IP层的一个runnel。它的作用相当于基于IP层的网桥一般来说,普通的网桥是基于mac层的,根本不需要IP,而这个ipip则是通过两端的路由作一个runnel,把两个本来不通的网络通过点对点连接起来

  • BGP

边界网关协议是互联网上一个核心的去中心化自治路由协议。它通过维护UP路由表或“前缀”表来实现自治系统(AS)之间的可达性,属于矢量路由协议。BGP不适用传统的内部网关协议(IGP)的指标,而使用基于路径、网络策略或规则集来决定路由。因此,它更适合被称为矢量协议,而不是路由协议。BGP,通俗的讲就是讲接入到机房的多条线路(如电信、联通、移动等)融为一体,实现多线单IP,BGP机房的优点:服务器只需要设置一个IP地址,最佳访问路由是由网络上的骨干路由器根据路由跳数与其他技术指标来确定的,不会占用服务器的任何系统

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

免费下载电子书的网站

在如今的数字化时代,电子书已成为许多人书籍阅读的首选。下面小编就和大家分享一些提供免费查找下载电子书服务的网站,这些网站不仅资源丰富,而且操作简便。 免费下载电子书的网站:https://www.bgrdh.com/favorites/1355.html 1…

数据可视化期末考试(编程)

1.KNN 1.新增数据的分类 import pandas as pd # 您的原始数据字典 data { 电影名称: [电影1, 电影2, 电影3, 电影4, 电影5], 打斗镜头: [10, 5, 108, 115, 20], 接吻镜头: [110, 89, 5, 8, 200], 电影类型: [爱情片, 爱情片, 动作片, 动作片, 爱情片] } …

昇思25天学习打卡营第8天 | 模型的保存与加载

内容介绍:在训练网络模型的过程中,实际上我们希望保存中间和最后的结果,用于微调(fine-tune)和后续的模型推理与部署,本章节我们将介绍如何保存与加载模型。 具体内容: 1. 导包 import numpy…

1.1 MySQL用户管理

1.1.1 用户的定义 用户名主机域 mysql> select user,host,password from mysql.user; --------------------------------------------------------------- | user | host | password | -----------------------------------------…

el-form重置后input无法输入问题

新增用户遇到的问题: 如果你没有为 formData 设置默认值,而只是将其初始化为空对象 {},则在打开dialog时,正常输入, formdata会变成如下 但是,打开后,直接使用 resetFields 或直接清空表单&…

LLDB 详解

LLDB 详解 LLDB 详解编译器集成优势LLDB 的主要功能命令格式原始(raw)命令选项终止符: -- LLDB 中的变量唯一匹配原则helpexpressionprint、call、po控制流程:continue、next、step、finishregister read / writethread backtracethread retu…

基于weixin小程序新生报到系统的设计

管理员账户功能包括:系统首页,个人中心,学生管理,班级信息管理,师资力量管理,宿舍信息管理,宿舍安排管理,签到信息管理,论坛管理 小程序功能包括:系统首页&am…

考研数学一有多难?130+背后的残酷真相

考研数学一很难 大家平时在网上上看到很多人说自己考了130,其实这些人只占参加考研数学人数的极少部分,有个数据可以展示出来考研数学到底有多难: 在几百万考研大军中,能考到120分以上的考生只有2%。绝大多数人的分数集中在30到…

【MySQL进阶之路 | 高级篇】MySQL8.0索引新特性->降序索引与隐藏索引

1. 支持降序索引 降序索引以降序存储键值.虽然在语法上,从MySQL4版本已经支持降序索引的语法了,但实际上该DESC定义是被忽略的.知道MySQL8.x版本才开始真正支持降序索引.(仅限于InnoDB存储引擎). MySQL在8.0版本前创建的仍然是升序索引,使用…

【C++11(二)】lambda表达式和可变参数模板

一、可变参数模板 C11的新特性可变参数模板 能够让您创建可以接受 可变参数的函数模板和类模板 // Args是一个模板参数包&#xff0c;args是一个函数形参参数包 // 声明一个参数包Args...args&#xff0c;这个参数包中可以包含0到任意个模板参数。 template <class ...Arg…

vue3 使用JsMind的方法,以及引入提示报错,无法找到模块“jsmind”的声明文件

最终结果&#xff1a; 一、使用&#xff1a;使用yarn或者npm 安装 yarn add jsmind npm install vue-jsmind 二、引入 两种方法&#xff1a;&#xff08;如果这样引入没问题按照这样引入&#xff09; import "jsmind/style/jsmind.css"; import JsMind from &quo…

【SSM】医疗健康平台-用户端-体检预约

知识目标 了解FreeMarker&#xff0c;能够简述FreeMarker的作用和生成文件的原理 熟悉FreeMarker的常用指令&#xff0c;能够在FTL标签中正确使用assign指令、include指令、if指令和list指令 掌握显示套餐列表功能的实现 掌握显示套餐详情功能的实现 掌握体检预约功能的实现…

nodejs——ejs模版遇到原型链污染产生rce

[GYCTF2020]Ez_Express 打开是一个登陆框 在源代码中找到 在代码里找到敏感关键字 找到merge 想到原型链污染 这里登陆只能用ADMIN才能登陆成功 但是这里index.php又设置了一个waf ban了admin的大小写 这里需要绕过这个waf 看注册这段代码 用的是这个toUpperCase()函数 之前…

【深度强化学习】如何使用多进程(multiprocessing、pipe)来加速训练

文章目录 实验结果实现思路思路1思路2 进程与线程介绍如何实现multiprocessing、Pipe的范例关于时间对比上的问题代码修改收敛为何不稳定 技巧进程资源抢占问题线程问题cpu和gpu问题 进阶&#xff08;还没看懂/还没实验&#xff09;附代码raw代码mul代码 实验结果 实验平台&am…

natsort 自然排序

1、安装 pip install natsort 2、为什么使用natsort 而不是sorted 在python中只需要调用sorted函数就可以了&#xff0c;但是这个函数有一个缺点&#xff0c;就是它是按照从第一位开始的顺序排列的。意思是&#xff1a; wav_file [1.wav, 13.wav, 9.wav, 2.wav,"23.wav…

Golang | Leetcode Golang题解之第198题打家劫舍

题目&#xff1a; 题解&#xff1a; func rob(nums []int) int {if len(nums) 0 {return 0}if len(nums) 1 {return nums[0]}first : nums[0]second : max(nums[0], nums[1])for i : 2; i < len(nums); i {first, second second, max(first nums[i], second)}return se…

图形编辑器基于Paper.js教程04: Paper.js中的基础知识

背景 了解paper.js的基础知识&#xff0c;在往后的开发过程中会让你如履平地。 基础知识 paper.js 提供了两种编写方式&#xff0c;一种是纯粹的JavaScript编写&#xff0c;还有一种是使用官方提供的PaperScript。 区别就是在于&#xff0c;调用paper下的字对象是否需要加pa…

Linux核心基础详解(第13天)

系列文章目录 一、Linux基础详解&#xff0c; 二、网编三要素和SSH原理 三、shell编程&#xff08;补充&#xff09; 文章目录 系列文章目录前言一、linux简介二、虚拟机简介1、设置VMware网卡1.1 修改VMware中网络1.2 修改本地net8网卡ip 2、安装命令版裸机3、安装centos操作…

Elasticsearch:使用 Llamaindex 的 RAG 与 Elastic 和 Llama3

这篇文章是对之前的文章 “使用 Llama 3 开源和 Elastic 构建 RAG” 的一个补充。我们可以在本地部署 Elasticsearch&#xff0c;并进行展示。我们将一步一步地来进行配置并展示。你还可以参考我之前的另外一篇文章 “Elasticsearch&#xff1a;使用在本地计算机上运行的 LLM 以…

【MySQL】 -- 事务

如果对表中的数据进行CRUD操作时&#xff0c;不加控制&#xff0c;会带来一些问题。 比如下面这种场景&#xff1a; 有一个tickets表&#xff0c;这个数据库被两个客户端机器A和B用时连接对此表进行操作。客户端A检查tickets表中还有一张票的时候&#xff0c;将票出售了&#x…