当前位置: 首页 > news >正文

K8s介绍(1)

一、Kubernetes 核心组件有哪些?分别是做什么的?创建 Pod 流程是什么?

✅ 1. Control Plane(控制平面)组件

组件

作用

kube-apiserver

K8s 的唯一入口,所有资源增删改查都通过它(认证 / 鉴权 / 准入控制)

etcd

分布式键值存储,保存集群所有资源状态(Pod、Service、RS 等)

kube-scheduler

调度 Pod,根据 CPU/内存/亲和性/污点等,选出合适的 Node

kube-controller-manager

运行多种控制器(Deployment / RS / Node / Namespace 等),保证期望状态一致

Master 节点 = apiserver + etcd + scheduler + controller-manager


✅ 2. Node(工作节点)组件

组件

作用

kubelet

每个 Node 一个,监听 apiserver,根据 PodSpec 拉镜像、启容器、汇报状态

kube-proxy

维护iptables / IPVS 规则,实现 Service → Pod 流量转发

Container Runtime

真正跑容器的(containerd / docker / CRI-O)


✅ 3. 创建一个 Pod 的完整流程(经典面试题)

kubectl create -f pod.yaml为例:

  1. kubectl

    • 校验 YAML

    • 调用kube-apiserverREST API

  2. kube-apiserver

    • 认证(证书 / token)

    • 鉴权(RBAC)

    • 准入控制(Admission)

    • 将 Pod 对象写入etcd(状态:Pending)

  3. kube-scheduler

    • 监听未调度的 Pod

    • 经过过滤(Filter)+ 打分(Score)

    • 选定 Node

    • 更新 Pod.spec.nodeName→ apiserver → etcd

  4. kubelet(对应 Node)

    • 监听到有 Pod 绑定到自己

    • 调用 Container Runtime 拉镜像

    • 创建容器、启动容器

    • 上报 Pod 状态(Running)→ apiserver → etcd

Pod 创建完成


二、Pod 是怎么“发布出来”被访问的?(今天的话术流程)

你写的这个思路是对的,标准访问链路话术如下:

纯文本

纯文本

Pod ↓ Service(ClusterIP / NodePort / LoadBalancer) ↓ kube-proxy(iptables / IPVS) ↓ 物理网卡(如 ens33)→ 转发到 Pod 的 veth

🔹 详细解释(口述版)

  1. Pod

    • 有独立 IP(CNI 插件分配,如 Calico/Flannel)

    • 只在集群内可达

  2. Service

    • 提供稳定虚拟 IP(VIP)和端口

    • 通过 LabelSelector 关联一组 Pod

    • Endpoints 记录真实 Pod IP

  3. kube-proxy

    • 监听 Service / Endpoints

    • 在 Node 上写iptables 或 IPVS 规则

    • Service IP:Port负载均衡到后端 Pod IP

  4. ens33(宿主机网卡)

    • NodePort / LB 类型时,外部流量进入 Node

    • kube-proxy 规则把流量转到 Pod(经过 cni0 / veth)

用户访问 Service → 实际访问 Pod


三、控制器管理 Pod 的逻辑(Deployment & ReplicaSet)

你写的层级完全正确:

纯文本

纯文本

Deployment → ReplicaSet → Pod

✅ 详细工作原理

1️⃣ Deployment
  • 声明应用期望版本 & 副本数

  • 管理ReplicaSet 的版本(滚动更新 / 回滚)

  • 不直接创建 Pod

yaml

yaml

deployment.spec.replicas = 3 deployment.spec.template = Pod模板
  • 修改镜像 → Deployment 创建新 ReplicaSet

  • 逐步 scale 新 RS ↑ / 旧 RS ↓(RollingUpdate)


2️⃣ ReplicaSet(RS)
  • 确保指定数量的 Pod 副本始终存在

  • 通过 LabelSelector 管理 Pod

  • 如果 Pod 挂了 → RS 新建 Pod

⚠️ RS 一般由 Deployment 创建,不建议手动写 RS


3️⃣ Pod
  • 最终被 kubelet 创建并运行

  • 无自愈能力(RS / Deployment 负责自愈)


✅ 控制器工作逻辑(核心思想)

期望状态(Spec) vs 实际状态(Status)

  • Controller 通过List-Watch 监听 apiserver

  • 实际 Pod 数 < replicas → 创建 Pod

  • 实际 Pod 数 > replicas → 删除 Pod

  • Pod 与 RS selector 不匹配 → 不管


✅ 面试一句话总结(高分答法)

Kubernetes 由 apiserver / etcd / scheduler / controller-manager 和 node 上的 kubelet / kube-proxy / runtime 组成;

Pod 由 Deployment → ReplicaSet → Pod 管理,经 apiserver 写入 etcd,scheduler 调度,kubelet 拉起;

外部通过 Service → kube-proxy(iptables/IPVS) → Node 网卡 → Pod 访问应用。

http://www.jsqmd.com/news/965717/

相关文章:

  • 从赌徒破产到网页排名:齐次马尔可夫链在算法面试中的高频考点解析
  • 用Arduino Uno和PAJ7620U2手势传感器做个智能灯控:从接线到代码调试的完整避坑指南
  • 从Tab切换案例出发,手把手教你用Chrome DevTools调试JavaScript事件与DOM状态
  • 概率密度函数与区域核:概念、验证与应用
  • GprMax正演模拟避坑指南:除了介电常数,这3个参数设置不当也会导致图像‘消失’
  • 实战指南:基于快马生成的php应用骨架,快速构建企业级内容管理系统
  • 从TC2到TC3,你的PLC代码升级了吗?聊聊那些必须注意的数据类型与对齐问题
  • SAP ABAP ALV编辑实战:手把手教你实现单元格联动更新与数据校验(附完整代码)
  • 从屏幕到代码:ColorWanted免费取色器的终极指南
  • 从STM32转战NXP LPC54114?手把手教你用Keil5点亮第一个LED(附完整工程)
  • 别再只用线性回归了!用sklearn的Ridge和Lasso轻松搞定特征多、样本少的预测难题
  • 别再直接用经纬度了!用Python的mgtwr包做GTWR建模,手把手教你处理时空数据的正确姿势
  • 不止是发现邻居:拆解IEEE 1905.1拓扑协议如何成为智能家居‘无缝漫游’的幕后功臣
  • 从Eclipse老手到STS新手:这10个SpringBoot开发必备设置,你配好了吗?
  • 前端打印PDF踩坑记:C-Lodop加载远程PDF链接为何打印空白?附完整解决方案
  • 自动驾驶、机器人避障都用它:深入浅出图解SGM(半全局匹配)算法,从原理到调参实战
  • SAP FICO后台配置避坑指南:从汇率到固定资产,新手必知的10个关键配置点
  • 别再乱用SCOPE了!ABAP锁机制深度解析:V1锁、V2锁与BAPI调用的那些事儿
  • 告别S3控制台!用MinIO Client(mc)命令行5分钟搞定文件同步与备份
  • 别只盯着64 GT/s!盘点PCIe 6.0那些可能更影响你实际项目的‘隐形’特性:FLIT、L0p与纠错
  • 从Oracle/MySQL转战国产库?手把手带你快速上手人大金仓Kingbase核心操作
  • OpenClaw v2026.5.28-beta.2 预发布解读:恢复能力、输入校验与覆盖范围扩展
  • 2026工业粉尘治理技术实测:收尘器、脉冲式除尘器、超低排放洗车机、车间降尘、雾森降尘、龙门洗车台、龙门洗车机定制选择指南 - 优质品牌商家
  • 告别开机弹窗!Vivado 18.3安装后必做的几项优化设置(附License配置避坑)
  • 软考 系统架构设计师历年真题集萃(276) —— 六边形架构(1)
  • 用BC547C三极管做个触摸开关?从达林顿管到单管电路的波形实测与选型建议
  • K8s介绍(2)POD架构
  • 从文件系统到网络库:聊聊Linux内核与开源项目中那些‘树’的实战应用
  • 告别单调点图条图:用clusterProfiler+ggplot2打造高颜值可发表的富集分析图
  • 从激光雷达回波到论文复现:深入解读Rclonte-M算法中的波形参数奥秘