【K8S系列】深入解析k8s网络

news2025/1/25 4:35:00

 序言

你只管努力,其他交给时间,时间会证明一切。

文章标记颜色说明:

  • 黄色:重要标题
  • 红色:用来标记结论
  • 绿色:用来标记一级论点
  • 蓝色:用来标记二级论点

Kubernetes (k8s) 是一个容器编排平台,允许在容器中运行应用程序和服务。今天学习一下k8s网络相关的内容

希望这篇文章能让你不仅有一定的收获,而且可以愉快的学习,如果有什么建议,都可以留言和我交流

 专栏介绍

这是这篇文章所在的专栏,欢迎订阅:【深入解析k8s】专栏

简单介绍一下这个专栏要做的事:

主要是深入解析每个知识点,帮助大家完全掌握k8s,以下是已更新的章节

这是专栏介绍文章地址:【深入解析K8S专栏介绍】

思考问题

     

 经过前面的学习,我们已经知道k8s是由各种组件、对象组成,那它是如何解决: 

  • Docker容器和Docker容器之间的网络?
  • Pod与Pod之间的网络?
  • Pod与Service之间的网络?
  • Internet与Service之间的网络?

1 基本介绍

1.1 K8s网络是什么

Kubernetes网络是指在Kubernetes集群中不同组件之间进行通信和交互的网络架构

在Kubernetes中,每个容器都有自己的IP地址,这些容器组成了Pod,Pod是Kubernetes调度的最小单元。

Kubernetes网络的设计目标是支持多种网络模型,并提供可插拔的网络插件,从而使Kubernetes能够在不同的云和物理环境中运行。

Kubernetes网络通常分为四个层次:

  • 容器网络接口(CNI)
  • Pod网络
  • Service网络
  • Ingress网络

 容器网络接口(CNI)层

Kubernetes网络的底层是CNI层,它是一个独立的插件系统,用于为容器分配IP地址、创建网络接口和配置网络环境。

CNI插件可以在Kubernetes的各种云和物理环境中使用,例如AWS、GCP、Azure、OpenStack、Bare metal等。

这一层解决的是—Docker容器和Docker容器之间的网络

Pod是最小的可调度单元,通常包含一个或多个容器。Pod内的容器可以通过localhost(127.0.0.1)进行通信,这种通信方式不需要网络环境的支持,因此可以实现较低的延迟和较高的吞吐量。

在Pod内部,容器之间可以通过共享网络命名空间进行通信。所有容器共享Pod的IP地址和网络命名空间,它们可以使用localhost或Pod的IP地址进行通信。可以通过在Pod的配置文件中指定容器之间的端口映射来定义容器之间的通信方式。

例如,在一个Pod中有两个容器A和B,A需要向B发送HTTP请求。可以在Pod的配置文件中为容器A和容器B分别指定端口号,然后在容器A中使用localhost和容器B的端口号进行通信。容器B在接收到请求后可以返回HTTP响应。

Pod网络层

Pod网络层是容器的网络层它为Pod提供了单独的IP地址和网络空间。Pod网络层可以使用多种网络模型,如host模式、overlay模式、macvlan模式等。

这一层解决的是—Pod与Pod之间的网络通讯

Pod间通信:

Pod是Kubernetes中最小的部署单元,每个Pod都有一个唯一的IP地址,Pod内的容器共享该IP地址和网络命名空间。

Pod间通信可以使用多种技术,如Kubernetes默认的CNI插件、Flannel、Calico、Weave Net等。

Service网络层

Service网络层是Kubernetes网络的中间层,它定义了Service之间的网络通信,为Service提供了一个虚拟IP地址,将请求路由到后端Pod的实际IP地址。

Service网络层可以使用ClusterIP、NodePort、LoadBalancer等多种类型。

这一层解决的是—Pod与Service之间的网络 

Ingress网络层

Ingress网络层是Kubernetes网络的顶层,它允许外部流量进入Kubernetes集群,并将请求路由到不同的Service。

Ingress网络层可以使用多种Ingress控制器,如Nginx、Traefik、HAProxy等。 

 这一层解决的是—Internet与Service之间的网络

2 k8s网络模型

Kubernetes网络模型是一个为容器提供网络连接的框架,它允许容器在Kubernetes集群内和外部进行通信。

Kubernetes网络模型包括以下几个方面:

  1. Pod间通信Pod是Kubernetes中最小的部署单元,每个Pod都有一个唯一的IP地址,Pod内的容器共享该IP地址和网络命名空间。Pod间通信可以使用多种技术,如Kubernetes默认的CNI插件、Flannel、Calico、Weave Net等

  2. Pod与Service通信Service是Kubernetes中用于访问Pod的一种抽象机制,它为一组Pod提供一个统一的访问入口,并分发请求到后端的Pod。Pod与Service之间的通信可以直接使用Service的IP地址或DNS名称,Kubernetes会自动将请求路由到后端的Pod。

  3. Pod与Node通信:Kubernetes中的Pod可以与它所在的节点进行通信,这种通信方式通常用于容器化应用需要访问宿主机上的资源,如宿主机上的文件、设备等。Pod与Node之间的通信可以通过节点IP地址或本地环回地址(127.0.0.1)进行。

  4. Service与外部网络通信:Kubernetes中的Service可以暴露给外部网络访问,这可以通过Ingress、NodePort或LoadBalancer等机制实现Ingress是一种Kubernetes中的资源对象,用于将外部HTTP/HTTPS流量路由到Service中,它可以提供负载均衡、SSL终止等功能。NodePort是一种Service类型,它将Service的端口映射到每个节点的固定端口上,从而允许外部网络通过节点IP地址和该端口访问Service。LoadBalancer是一种Service类型,它使用云提供商的负载均衡器将外部网络流量路由到Service中。

Kubernetes网络模型提供了一种灵活、可扩展、高可用、安全的网络解决方案,使得容器之间能够相互通信以及与外界进行通信,为容器化应用的部署和运行提供了强大的支持。

网络方案

Kubernetes网络模型是基于容器、Pod、Service和Ingress等抽象概念构建的,它提供了以下特性:

  1. 容器间通信容器可以直接通过Pod网络进行通信,无需进行端口映射或NAT

  2. Service发现:Service网络层为Service提供了一个虚拟IP地址,使得其他容器可以通过Service名称和端口号访问该服务。

  3. 负载均衡:Kubernetes支持多种负载均衡算法,如Round Robin、IP Hash、Least Connection等。

  4. 网络隔离:Kubernetes支持通过网络策略实现容器之间的网络隔离,从而保护容器的安全性。

  5. 外部流量管理:Ingress网络层提供了外部流量管理机制,允许外部请求进入Kubernetes集群,并将请求路由到不同的Service。

Kubernetes网络架构和网络模型提供了高度可扩展性、可插拔性和高可用性的网络解决方案,使得开发人员可以更加轻松地部署和管理容器化应用程序。

k8s网络插件

Kubernetes 是一个强大的容器编排平台,它提供了多种网络插件,用于在集群中实现容器之间和容器与外部网络的通信。以下是几种常用的 Kubernetes 网络插件:

  1. Kube-router
  2. Flannel
  3. Calico
  4. Weave Net
  5. Cilium

1 Kube-router

Kube-router 是一种基于 BGP 协议的容器网络方案它可以在集群中创建一个虚拟网络,并使用 BGP 协议来管理容器之间的通信。

具体来说,Kube-router 会为每个容器分配一个唯一的 IP 地址,并使用 BGP 协议将这些 IP 地址添加到路由表中。

Kube-router 还支持多种网络拓扑结构,包括扁平网络、网格网络和点对点网络等。

使用示例

以下是使用 Kube-router 网络插件的示例代码,

演示前提:已经安装了 Kubernetes 集群和 Kube-router 网络插件:

创建一个 Kubernetes Deployment

apiVersion: apps/v1
kind: Deployment #资源类型为Deployment
metadata:
  name: nginx-deployment
spec:
  replicas: 2
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:latest
        ports:
        - containerPort: 80

创建一个 Kubernetes Service

apiVersion: v1
kind: Service #资源类型为service
metadata:
  name: nginx-service
spec:
  selector:
    app: nginx
  ports:
    - name: http
      port: 80
      targetPort: 80
  type: ClusterIP

创建一个 Kubernetes Pod,使用 Kube-router 网络插件

apiVersion: v1
kind: Pod  #资源类型为pod
metadata:
  name: kube-router-pod
spec:
  containers:
  - name: kube-router-container
    image: kube-router/kube-router:v1.3
    command:
    - kube-router
    - run
    args:
    - --run-router=false
    - --run-firewall=false
    - --run-service-proxy=false
    - --run-egress=false
    - --enable-cni=true
    - --cni-bin-dir=/opt/cni/bin
    - --cni-conf-dir=/etc/cni/net.d
    - --cni-network-config='{
        "cniVersion": "0.3.1",
        "name": "kube-router",
        "type": "kube-router"
      }'
    volumeMounts:
    - name: cni-bin
      mountPath: /opt/cni/bin
    - name: cni-conf
      mountPath: /etc/cni/net.d
  volumes:
  - name: cni-bin
    hostPath:
      path: /opt/cni/bin
  - name: cni-conf
    hostPath:
      path: /etc/cni/net.d

在该示例中,

创建了一个 Pod,并使用 Kube-router 网络插件来管理容器的网络配置。

具体来说,是在容器中启动了 Kube-router 进程,并通过命令行参数来配置插件的运行模式和网络配置。

还使用了 hostPath 卷来挂载 CNI 插件所需的文件和配置。

需要注意的是,在使用 Kube-router 网络插件时,需要根据不同的网络需求和环境来配置参数和选项。具体的配置方法可以参考 Kube-router 的官方文档和示例代码。

2 Flannel

Flannel 是一种基于 VXLAN 或者 UDP 的虚拟网络方案,它通过在每个节点上创建一个虚拟网络来实现容器之间的通信。

具体来说,Flannel 会为每个节点分配一个唯一的 IP 地址段,并将每个容器的 IP 地址映射到这个 IP 地址段中。

Flannel 需要依赖 etcd 或者其他分布式键值存储系统来存储网络配置信息

使用示例 

以下是使用 Flannel 网络插件的示例代码,

演示前提:已经安装了 Kubernetes 集群和 Flannel 网络插件:

创建一个 Kubernetes Deployment

apiVersion: apps/v1
kind: Deployment #资源类型
metadata:
  name: nginx-deployment
spec:
  replicas: 2
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:latest
        ports:
        - containerPort: 80

创建一个 Kubernetes Service

apiVersion: v1
kind: Service #资源类型
metadata:
  name: nginx-service
spec:
  selector:
    app: nginx
  ports:
    - name: http
      port: 80
      targetPort: 80
  type: ClusterIP

创建一个 Kubernetes Pod,使用 Flannel 网络插件

apiVersion: v1
kind: Pod #资源类型
metadata:
  name: flannel-pod
spec:
  containers:
  - name: flannel-container
    image: quay.io/coreos/flannel:v0.14.0
    command:
    - /opt/bin/flanneld
    args:
    - --ip-masq
    - --kube-subnet-mgr
    - --iface=eth0
    securityContext:
      privileged: true
    volumeMounts:
    - name: flannel-cfg
      mountPath: /etc/kube-flannel/
  volumes:
  - name: flannel-cfg
    configMap:
      name: kube-flannel-cfg #挂载

在该示例中,创建了一个 Pod,并使用 Flannel 网络插件来管理容器的网络配置。另外,在容器中启动了 Flannel 进程,并通过命令行参数来配置插件的运行模式和网络配置。

还使用了 configMap 卷来挂载 Flannel 的配置文件。

需要注意的是,在使用 Flannel 网络插件时,需要根据不同的网络需求和环境来配置参数和选项

具体的配置方法可以参考 Flannel 的官方文档和示例代码。

3 Calico

Calico 是一种基于 BGP 协议的容器网络方案,它使用 IP 路由表来管理容器之间的通信。具体来说,Calico 会为每个容器分配一个唯一的 IP 地址,并使用 BGP 协议将这些 IP 地址添加到路由表中。Calico 还提供了强大的网络安全机制,可以保护容器网络的安全性。

4 Weave Net

Weave Net 是一种基于 VXLAN 或者 UDP 的虚拟网络方案,它可以在集群中创建一个虚拟网络,从而实现容器之间的通信。具体来说,Weave Net 会为每个容器分配一个唯一的 IP 地址,并使用 VXLAN 或者 UDP 来在不同节点之间传输数据。Weave Net 还支持多种网络拓扑结构,包括扁平网络、网格网络和点对点网络等。

5 Cilium

Cilium 是一种基于 eBPF 技术的容器网络方案,它可以在内核层面拦截和管理容器之间的通信。具体来说,Cilium 会在每个节点上创建一个 eBPF 过滤器,用于监控和管理容器之间的数据流。Cilium 还支持多种网络层协议和应用层协议,并提供了强大的网络安全机制,可以保护容器网络的安全性。

总结

Kubernetes 提供了多种网络插件,可以根据不同的网络需求和环境来选择适合的网络方案。需要注意的是,在进行网络插件的选择和部署时,需要考虑网络的可靠性、性能和安全性等因素。

今天就到这里了,后面详细介绍:

K8s网络问题解决方案

  • 网络故障排除
  • 网络性能优化
  • 网络安全
  • 实战案例

投票

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

(8) 支持向量机分类器SVC案例:预测明天是否会下雨

文章目录 案例介绍1 导库导数据,探索特征2 分集,优先探索标签3 探索特征,开始处理特征矩阵3.1 描述性统计与异常值3.2 处理困难特征:日期3.3 处理困难特征:地点3.4 处理分类型变量:缺失值3.5 处理分类型变量…

Typora + PicGo + Gitee 搭建免费图床

搭建准备 本次搭建过程需要以下介质:Typora PicGo Gitee/GitHub ,「免费!」 Typora Typora 是一款 markdown 编辑器,支持几乎所有的 markdown 格式,神器! 支持 macOS、Windows、Linux 三种操作系统&am…

Composition API 的优势、新的组件(Fragment,Teleport,Suspense)【Vue3】

四、Composition API 的优势 1. Options API 存在的问题 使用传统OptionsAPI中,新增或者修改一个需求,就需要分别在data,methods,computed里修改。 2. Composition API 的优势 我们可以更加优雅的组织我们的代码&#xff0c…

Packet Tracer - 在思科路由器上配置 AAA 认证

Packet Tracer - 在思科路由器上配置 AAA 认证 拓扑图 地址分配表 设备 接口 IP 地址 子网掩码 默认网关 交换机端口 R1 G0/1 192.168.1.1 255.255.255.0 不适用 S1 F0/1 S0/0/0 (DCE) 10.1.1.2 255.255.255.252 不适用 不适用 R2 G0/0 192.168.2.1 255.2…

(4)基本组件

目录 1. Designer 设计师** 2. Layout 布局*** 3. 基本组件 3.1 QWidget** 3.2 ui指针 3.3 QLabel 标签** 3.4 QAbstractButton 按钮类** 示例 1. Designer 设计师** Designer是一款独立的用于设计Qt界面的应用程序。 Designer程序保存的文件格式为.ui,这是Qt中的界…

腾讯云轻量应用服务器修改镜像系统有哪些限制?

腾讯云轻量应用服务器镜像可以更换或修改吗?可以!镜像可以修改,镜像是指轻量服务器的预装操作系统,轻量服务器创建成功后镜像也是可以更换的。 镜像是轻量服务器的预装操作系统,轻量应用服务器的镜像不仅包含操作系统&…

看我如何通过帮助服务台轻松黑掉数百家公司

导语:几个月前,我发现黑客可以利用一个漏洞访问目标公司的内部通信。 这个漏洞只需要点击几下,就可以访问企业内部网络、 Twitter等社交媒体账户,以及最常见的Yammer和Slack团队。 更新: The Next Web 写了一篇我发现的这个漏洞的…

SAP BusinessObjects BI crack

SAP BusinessObjects BI crack 通过基于驱动程序标准的数据库、报告工具,甚至自定义应用程序,加入SAP BusinessObjects BI报告和分析。 与BI分析、报告、ETL工具和自定义解决方案集成。 SAP BusinessObjects BI奇妙功能中的CData驱动程序: BI…

数据结构与算法基础(王卓)(35):交换排序之快排【第一阶段:第一遍遍历】

目录 快速排序: 法一: 法二:(常用、重难点) 第一阶段:第一遍遍历 Project 1: 问题: Project 2: 问题: Project 3: 问题: Project 4: Project 5: 快速排序&am…

spring-模型数据和视图---视图解析器的说明以及大量代码演示

目录 spring-模型数据 ● 说明 应用实例需求 创建后面所有代码执行成功之后跳转的vote_ok.jsp页面 方式 1: 通过 HttpServletRequest放入 request 域 创建 Master类 创建Pet类 创建model_data.jsp 修改 VoteHandler增加方法 创建vote_ok.jsp, 显示数据 完成测试(Post…

初级算法-动态规划

主要记录算法和数据结构学习笔记,新的一年更上一层楼! 初级算法-动态规划 一、斐波那契数二、爬楼梯三、使用最小花费爬楼梯四、不同路径五、不同路径二六、整数拆分七、不同的二叉搜索树八、0-1背包九、分割等和子集十、最后一块石头的重量十一、目标和…

深入浅出分支语句—【C语言】

目录 前言:为什么要学习分支和循环语句呢? 1. 语句的分类 2. 分支语句(选择语句) 2.1 if-else语句 注意点:if-else语句后面不加{},默认只能跟一条语句 2.2 switch语句 注意点: 前言&…

平衡二叉树旋转机制

概念 平衡二叉树的旋转机制是一种通过对树进行旋转操作来保持其平衡的方法。 分类 平衡二叉树的旋转机制包括两种基本类型的旋转:左旋和右旋,以及它们的组合。 左旋 左旋是将一个节点的右子节点旋转到它的位置上,同时将该节点移到其左侧&…

关于低代码开发,你是真的了解了吗?

在低代码开发已是大势所趋的今天,不少企业都切身感受到了低代码开发带来的便利。低代码开发平台的优势在当下数字化浪潮中,为企业提供了定制专属的数字化解决方案。 低代码本身没有太强的行业属性,这也让低代码开发平台能够更加灵活地适应不同…

嵌入式 QT 界面布局管理

目录 1、实例程序功能 2、界面组件布局 2.1 界面组件的层次关系 2.2 布局管理 2.3 伙伴关系和Tab顺序 1、实例程序功能 创建一个 Widget Application 项目 samp2_2, 在创建窗体时选择基类 QDialog ,生成的类命名为 QWDialog ,并选择…

Python实用记录(十三):python脚本打包exe文件并运行

文章目录 打包准备文件准备环境安装 具体运行第一步第二步第三步 注意 打包准备 文件准备 这里准备一个简单的python代码(打开电脑摄像头) import cv2 if __name__ __main__:cap cv2.VideoCapture(0)ret, frame cap.read()while ret:ret, frame c…

希亦洗地机和添可洗地机哪个好用?口碑洗地机详细对比

在当今这个科技发达的社会,为了能够帮助人们高效率的工作,各色各样的发明不断出现。扫地、拖地是我们日常生活中再普通不过的一项家务了,对于小型的房子而言打扫起来就比较轻松,对于繁忙的上班族打扫空间较大的房子就很困难&#…

Undo Log详解

undo log 基本概念 undo log是一种用于撤销回退的日志,在数据库事务开始之前,MySQL会先记录更新前的数据到undo log日志文件里面,当事务回滚时或者数据库崩溃时,可以利用 undo log来进行回退 Undo Log产生和销毁:Und…

redis(2)

缓存:缓存是一个高速数据交换的存储器,使用它可以迅速的访问和操作数据 因为单体应用已经不适用于现在的环境了,所以最终变成分布式系统,本地缓存已经不适用了 1)比如说张三用户访问了应用程序nginx把请求分配给A服务器 A机器查询数据库,并且把数据库的结…

模型实战(11)之win10下Opencv+CUDA部署yolov5、yolov8算法

win10下Opencv+CUDA部署yolov5、yolov8算法 测试环境:AMDRH7000+RTX3050+win10+vs2-10+opencv455+cuda11.7关于opencv470+contrib+cuda的编译,可以详见:Win10下Opencv+CUDA联合编译详细教程本文代码同时支持yolov5、yolov8两个模型,详细过程将在文中给出,完整代码仓库最后…