【K8s】K8s的声明式API核心

在看K8s官方文档时,发现networkpolicy网络策略资源在K8s API目录下,由这一点对K8s的声明式API驱动和控制平面与数据平面分离又有了新的理解。分享给大家。

​Kubernetes 不自己实现网络功能,但它通过 API 对象来定义和声明"所需的网络状态",然后由第三方网络插件(CNI)来接收这个声明并负责实现它。​

Kubernetes API Server 是所有这些声明的唯一真相来源(Source of Truth)。NetworkPolicy 作为一个 API 资源,意味着网络策略的定义、存储、校验和分发都是由 Kubernetes 核心统一管理的。

层面 角色 在 NetworkPolicy 中的体现
​控制平面 (Control Plane)​ ​做出决策​​,下发规则。 ​Kubernetes API Server 和控制器:​ ​ 1. 接收用户提交的 NetworkPolicy YAML。 2. 验证其合法性并存入 etcd。 3. 将策略的"声明"下发到各个节点。
​数据平面 (Data Plane)​ ​执行决策​​,处理实际的数据包。 ​CNI 网络插件(如 Calico, Cilium, Weave Net):​ ​ 1. ​​监听​ ​ API Server 的 NetworkPolicy 变化。 2. ​​将​ ​ NetworkPolicy 的声明​​转换​ ​为具体的、可执行的网络规则(如 iptables 规则、eBPF 程序)。 3. 在数据路径上​​实施​​这些规则,真正地允许或拒绝流量。
  • 你定义策略时,使用的是 ​​Pod 标签选择器(Selectors)​ ​、​​命名空间(Namespace)​​,而不是传统的 IP 地址、子网、网卡。

  • 这意味着开发者/运维人员可以继续使用他们熟悉的 Kubernetes 概念(标签、命名空间)来管理网络安全,而无需深入了解底层的复杂网络知识(IP 地址管理、路由协议、防火墙命令)。

NetworkPolicy 被列为 Kubernetes API 下的一个资源,反映了一种高度抽象、声明式、解耦的现代化系统设计结构:

  1. 声明式 API 驱动​​:NetworkPolicy 是用户向系统声明的"期望网络状态"。

  2. ​控制平面与数据平面分离​​:Kubernetes 核心作为控制平面负责管理和下发声明;CNI 插件作为数据平面负责具体实现。

  3. ​以应用为中心​​:策略使用应用层概念(标签、命名空间)进行定义,而不是底层网络细节。

  4. ​生态扩展性​​:通过标准化的 API,Kubernetes 成功地将网络能力外包给了专业的第三方插件,构建了强大的生态系统。

相关推荐
张3234 小时前
K8s控制器学习难点
云原生·容器·kubernetes
小猿姐5 小时前
实测对比:哪款开源 Kubernetes MySQL Operator 最值得用?(2026 深度评测)
数据库·mysql·云原生
qwy7152292581637 小时前
1-Docker Engine 安装前置环境配置
运维·docker·容器
sszdzq10 小时前
docker 安装 doris
运维·docker·容器
海的透彻12 小时前
docker容器进程探究
运维·docker·容器
❀͜͡傀儡师12 小时前
ShadowBroker:实时全球情报地图,开源情报(OSINT)的终极聚合平台
docker·容器·llama
么卡12 小时前
我在 Debian 11 上把 K8s 单机搭起来了,过程没你想的那么顺(/opt 目录版)
kubernetes
AI攻城狮13 小时前
Adaptive Thinking 的代价:当 AI 自己决定"想多少"
人工智能·云原生·aigc
Dontla14 小时前
Kubernetes Liveness Probe存活探针 / Readiness Probe就绪探针介绍(Startup Probe启动探针)重启容器
云原生·容器·kubernetes
格林威14 小时前
工业相机 SDK 在 Docker 容器中的部署与权限配置(含 USB/GigE)
开发语言·人工智能·数码相机·计算机视觉·docker·容器·工业相机