Kubernetes网络CNI插件:Flannel与Calico详解

LogicCipherX
• 阅读 242

Kubernetes 网络模型基于插件架构设计,容器网络接口(CNI)插件负责具体的网络通信。

Kubernetes 网络概述

  1. 网络职责划分

    • Kubernetes 本身不负责网络通信:Kubernetes 提供了容器网络接口 CNI(Container Network Interface),具体的网络通信交给 CNI 插件来负责。
    • CNI 插件:开源的 CNI 插件有很多种,如 Flannel、Calico 等。不同的插件实现不同的网络功能和特性。
    • VPC 网络支持:CCE(云容器引擎)专门为 Kubernetes 定制了 CNI 插件(如 Canal 和 Yangste),使得 Kubernetes 可以使用 VPC 网络。
  2. 网络连接机制

    • Pod 互相通信:Kubernetes 集群中的 Pod 能够互相通信,且必须通过非 NAT 网络连接。即收到的数据包的源 IP 是发送数据包的 Pod 的 IP。
    • Pod 与节点之间通信:Pod 与节点之间的通信也是通过非 NAT 网络。但在 Pod 访问集群外部时,源 IP 会被修改成节点的 IP。

使用 Flannel 进行 Kubernetes 网络配置

  1. 安装 Flannel
    在 Kubernetes 集群中安装 Flannel 作为 CNI 插件。可以使用以下命令来安装 Flannel:

    kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
  2. Flannel 配置示例
    Flannel 的配置文件内容如下:

    apiVersion: policy/v1beta1
    kind: PodSecurityPolicy
    metadata:
      name: psp.flannel.unprivileged
    spec:
      privileged: false
      volumes:
        - configMap
        - secret
        - emptyDir
        - hostPath
      allowedHostPaths:
        - pathPrefix: "/etc/cni/net.d"
        - pathPrefix: "/etc/kube-flannel/"
        - pathPrefix: "/run/flannel/"
      hostNetwork: true
      hostPorts:
        - min: 0
          max: 65535
      hostPID: false
      hostIPC: false
      seLinux:
        rule: RunAsAny
      supplementalGroups:
        rule: RunAsAny
      runAsUser:
        rule: RunAsAny
      fsGroup:
        rule: RunAsAny
      readOnlyRootFilesystem: false
  3. 验证网络配置
    验证网络配置是否生效。创建两个 Pod 并验证它们之间的网络连通性:

    kubectl run --rm -it --image=busybox pod1 -- /bin/sh
    # 在 Pod1 中执行
    wget -qO- http://pod2-ip-address
  4. 节点之间的通信
    Flannel 默认使用 VXLAN 来在不同节点之间创建一个覆盖网络,使得不同节点上的 Pod 能够互相通信。可以通过以下命令查看 Flannel 配置的网络接口:

    ip a | grep flannel

使用 Calico 进行 Kubernetes 网络配置

  1. 安装 Calico
    选择 Calico 作为 CNI 插件。可以使用以下命令来安装 Calico:

    kubectl apply -f https://docs.projectcalico.org/v3.14/manifests/calico.yaml
  2. Calico 配置示例
    Calico 的配置文件内容如下:

    apiVersion: v1
    kind: ConfigMap
    metadata:
      name: calico-config
      namespace: kube-system
    data:
      # 设置 Calico 的后端类型为 vxlan
      calico_backend: "vxlan"
      # 设置 BGP 的启用
      enable_bgp: "true"
  3. 验证网络配置
    验证 Calico 配置的网络连通性:

    kubectl run --rm -it --image=busybox pod1 -- /bin/sh
    # 在 Pod1 中执行
    wget -qO- http://pod2-ip-address
  4. Calico 的特性
    Calico 除了提供基本的网络功能外,还提供了更高级的网络策略管理功能,可以通过定义 NetworkPolicy 来控制 Pod 之间的通信。例如:

    apiVersion: networking.k8s.io/v1
    kind: NetworkPolicy
    metadata:
      name: allow-all
      namespace: default
    spec:
      podSelector: {}
      policyTypes:
        - Ingress
        - Egress
      ingress:
        - {}
      egress:
        - {}

Kubernetes 的网络模型依赖于 CNI 插件来实现具体的网络通信功能。不同的 CNI 插件(如 Flannel 和 Calico)提供了不同的功能和特性,用户可以根据需求选择合适的插件进行部署和配置。通过正确配置 CNI 插件,可以确保 Kubernetes 集群中的 Pod 和节点之间实现高效、可靠的网络通信。

本文由mdnice多平台发布

点赞
收藏
评论区
推荐文章
Bill78 Bill78
4年前
k8s超详细总结
一个目标:容器操作;两地三中心;四层服务发现;五种Pod共享资源;六个CNI常用插件;七层负载均衡;八种隔离维度;九个网络模型原则;十类IP地址;百级产品线;千级物理机;万级容器;相如无亿,K8s有亿:亿级日服务人次。一个目标:容器操作Kubernetes(k8s)是自动化容器操作的开源平台。这些容
Stella981 Stella981
4年前
Kubernetes 部署 Nebula 图数据库集群
Kubernetes是一个开源的,用于管理云平台中多个主机上的容器化的应用,Kubernetes的目标是让部署容器化的应用简单并且高效,Kubernetes提供了应用部署,规划,更新,维护的一种机制。<br/Kubernetes在设计结构上定义了一系列的构建模块,其目的是为了提供一个可以部署、维护和扩展应用程序的机制,组成Kubernetes
如何接入 K8s 持久化存储?K8s CSI 实现机制浅析
作者王成,腾讯云研发工程师,Kubernetescontributor,从事数据库产品容器化、资源管控等工作,关注Kubernetes、Go、云原生领域。概述进入K8s的世界,会发现有很多方便扩展的Interface,包括CSI,CNI,CRI等,将这些接口抽象出来,是为了更好的提供开放、扩展、规范等能力。K8s持久化存储经历了从in
Stella981 Stella981
4年前
Kubernetes 容器网络模型和典型实现
\\导读:\\前文Kubernetes中的ClusterIP、NodePort、LoadBalancer、Ingress服务访问方式比较(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fwww.atatech.org%2Farticles%2F156810)中总结了服
Stella981 Stella981
4年前
Kubernetes(十二)部署K8s集群网络(flannel)
cni是k8s的一个接口,如果需要对接k8s就需要遵循cni接口标准,部署cni主要是为了接通第三方网络;关于第三方网络插件实现 https://kubernetes.io/docs/setup/productionenvironment/tools/kubeadm/createclusterkubeadm/(https://www.osch
Stella981 Stella981
4年前
Kubernetes源码探疑:Pod IP泄露排查及解决
作者:陈绥来源:UCloud(ID:ucloud\_tech)UK8S是UCloud推出的Kubernetes容器云产品,完全兼容原生API,为用户提供一站式云上Kubernetes服务。我们团队自研了CNI(Container Network Interface)网络插件,深度集成VPC,使UK8S容器应用拥有与云主机间等同的网络性能(目前
Stella981 Stella981
4年前
Kubernetes面试题超详细总结
来自:stackpush| 责编:乐乐链接:blog.csdn.net/huakai\_sun/article/details/82378856正文一个目标:容器操作;两地三中心;四层服务发现;五种Pod共享资源;六个CNI常用插件;七层负载均衡;八种隔离维度;九个网络模型原则;十类IP地址;百级产品
Wesley13 Wesley13
4年前
K8S CNI及各CNI网络解决方案简述
CNi:什么是CNI?CNI是ContainerNetworkInterface的缩写,是一个标准的通用的接口。为了让用户在容器创建或销毁时都能够更容易地配置容器网络,现在容器平台:docker,kubernetes,mesos。CNI如何实现?CNI用于连接容器管理系统和网络插件。提供一个容器所在的networknam
Stella981 Stella981
4年前
Kubernetes Egress 网络策略指南
作者:ViswajithVenugopal翻译:Bach(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fmp.weixin.qq.com%2Fs%2F0FIe_5ojwF0NC8FviKFPCQ)(才云(https://www.oschina.net/action
Stella981 Stella981
4年前
Kubernetes网络分析之Flannel
Flannel是cereos开源的CNI网络插件,下图flannel官网提供的一个数据包经过封包、传输以及拆包的示意图,从这个图片里面里面可以看出两台机器的docker0分别处于不同的段:10.1.20.1/24和10.1.15.1/24,如果从WebAppFrontend1pod(10.1.15.2)去连接另一台主机上的Backend
Stella981 Stella981
4年前
Kubernetes网络分析之Flannel工作原理及源码实现
Flannel是cereos开源的CNI网络插件,下图flannel官网提供的一个数据包经过封包、传输以及拆包的示意图,从这个图片中可以看出两台机器的docker0分别处于不同的段:10.1.20.1/24和10.1.15.1/24,如果从WebAppFrontend1pod(10.1.15.2)去连接另一台主机上的BackendService