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

Deployment 部署 Pod 流程

文章目录

  • k8s组件介绍
  • 部署文件示例
  • 部署 Pod 流程
  • 创建 Service

通过创建 Deployment 资源,来看看 k8s 部署 Pod 流程

k8s组件介绍

首先看看 k8s 各组件功能。

  • control plane 控制平面主要包含以下组件:

    kube-api-server: 顾名思义,负责处理所有 api,包括客户端以及集群内部组件的请求。
    etcd: 分布式持久化存储、事件订阅通知。只有 kube-api-server 直接操作 etcd,其它所有组件都是与 kube-api-server 进行相互。
    scheduler: 处理 pod 的调度,将 pod 绑定到具体的 node 节点。
    controller manager: 控制器,处理各种资源对象。
    cloud controller manager: 对接云服务商的控制器。

  • node 节点,主要部署用户的应用程序,主要包含以下组件:

    kubelet: 管理节点上的 pod 以及状态检查和上报。
    kube-proxy: 进行流量的路由转发(目前是通过操作节点的 iptables 或者 ipvs 实现)。
    container runtime: 容器运行时,例如 containerd。

部署文件示例

Deployment:

apiVersion: apps/v1
kind: Deployment
metadata:name: nginx-demolabels:app: nginx
spec:replicas: 2selector:matchLabels:app: nginxtemplate:metadata:labels:app: nginxspec:containers:- name: nginximage: nginx:latestports:- containerPort: 80

Service:

apiVersion: v1
kind: Service
metadata:name: nginx-service
spec:selector:app: nginxports:- protocol: TCPport: 80targetPort: 80type: ClusterIP

部署 Pod 流程

在这里插入图片描述

  1. 用户提交yaml文件给 kube-api-server,api-server 将 Deployment 内容持久化到 etcd中。
  2. controller-manager 监听到 Deployment 创建事件后,检查相应的 RepliccasSet 是否创建。如果没有创建,则创建 ReplicasSet
  3. controller-manager 监听到 ReplicasSet 创建事件后,检查该 ReplicasSet 关联的 Pod 是否符合 ReplicasSet 期望的状态。如果不符合,则创建Pod。
  4. Scheduler 监听到 Pod 创建事件后,根据 Pod 配置中指定的调度算法,过滤,打分计算出适合 Pod 运行的最佳节点,然后将绑定的节点名称更新到该 Pod 信息中。
  5. kubelet 监听到有 Pod 调度到自己所在的节点,然后调用 CRI 接口创建容器。

创建 Service

在这里插入图片描述

  1. 用户提交yaml文件给 kube-api-server,api-server 将 Deployment 内容持久化到 etcd中。
  2. controller-manager 监听到 Service 创建事件后,根据 Service 和 Pod 的关联关系创建 Endpoint,并将 Endpoint 信息持久化到 etcd 中。
  3. kube-proxy 监听 Service,Endpoint 事件,在节点上创建相应的网络规则。
http://www.lryc.cn/news/527215.html

相关文章:

  • 塔罗牌(基础):大阿卡那牌
  • TCP/IP 协议:互联网通信的基石
  • Python 之 Excel 表格常用操作
  • 2025春招 SpringCloud 面试题汇总
  • jupyter版本所引起的扩展插件问题
  • 01机器学习入门
  • 实现一个安全且高效的图片上传接口:使用ASP.NET Core和SHA256哈希
  • PyTorch中的movedim、transpose与permute
  • HTTP(1)
  • C#常考随笔2:函数中多次使用string的+=处理,为什么会产生大量内存垃圾(垃圾碎片),有什么好的方法可以解决?
  • leetcode刷题记录(一百)——121. 买卖股票的最佳时机
  • MATLAB绘图时线段颜色、数据点形状与颜色等设置,介绍
  • CIMRTS材质美化--放大采样、缩小采样
  • P8738 [蓝桥杯 2020 国 C] 天干地支
  • PyCharm接入DeepSeek实现AI编程
  • Java编程语言:辉煌的历史与未来前景
  • 麦田物语学习笔记:保存和加载场景中的物品
  • 页高速缓存与缓冲区缓存的应用差异
  • 深度学习 Pytorch 单层神经网络
  • 一文读懂 HTTP:Web 数据交换的基石
  • 算法知识补充2
  • Vue.js组件开发-实现对视频预览
  • SSM开发(三) spring与mybatis整合(含完整运行demo源码)
  • .NET MAUI进行UDP通信(二)
  • 14-6-3C++STL的list
  • AAAI2024论文解读|HGPROMPT Bridging Homogeneous and Heterogeneous Graphs
  • WPA_cli P2P命令详解及使用
  • 【竞技宝】LPL:IG3-1击败RNG
  • sqlite3 学习笔记
  • Visual Studio Community 2022(VS2022)安装方法