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

K8S中,pod的创建流程

kubelet创建pod流程

流程图

在这里插入图片描述

OCI(Open Container Initiative)是一个由docker社区发起的项目,Docker、containerd

CNI(Container Network Interface)网络配置:为容器分配IP地址、配置网络接口、设置路由

CSI(Container Storage Interface),存储卷的创建与删除:支持动态创建和删除持久存储卷。卷的挂载与卸载:将存储卷挂载到容器中,使得容器能够读写数据。

文字版pod创建全流程

  • 用户把资源清单发送到api-server

  • api-server对来源数据进SSL证书验证、语法验证、权限验证(RBAC),验证通过后把相关信息写入到etcd

  • controler-manager通过watch实践监听到了etcd数据的变化,发现有控制器deploy 需要创建

scheduler通过watch监听到etcd数据发生变化,

1.kubelet组件调用 CRI(Container Runtime Interface容器运行接口)

符合cri规范的有:containerddcri-opodmancri-docker (也叫 docker-shim K8S 1.24移除)

2.run创建容器。OCI(开源容器提议),runc符合这一点。大部分CRI底层都是调用的 runc

容器创建阶段:

3.启动 pause 基础架构容器负责网络名称空间初始化

4.如果有初始化容器就会初始化容器

5.启动业务容器后先调用postStart函数;(启动容器时一次性

6.调用startupProbe探针;(启动容器时一次性)

7.周期性调用 livenessProbe 和 readinessProbe(启动容器后周期性执行)

8.当容器退出时,调用preStop函数,该函数必须在优雅终止。(terminationGracePeriodSeconds,若不定义,默认值为30s)之前结束;


http://www.kler.cn/a/457913.html

相关文章:

  • vue实现下拉多选、可搜索、全选功能
  • 矩阵的因子分解1-奇异值分解
  • 前端页面上传文件:解决 ERR_UPLOAD_FILE_CHANGED
  • An object could not be cloned 错误
  • ts总结一下
  • Django Settings 优化与常用配置指南
  • Spring Boot对访问密钥加解密——HMAC-SHA256
  • 前端正在被“锈”化
  • [modern c++] 不要对一个对象创建多个 shared_ptr
  • 查看helm 版本
  • C++软件设计模式之策略模式
  • 目标检测文献阅读-YOLO:统一的实时目标检测(12.23-12.29)
  • Go的对象在内存中分配原理
  • 使用 Webpack 优雅的构建微前端应用❕
  • C++ 设计模式:工厂方法(Factory Method)
  • QT 学习第十四天
  • 8-Gin 中间件 --[Gin 框架入门精讲与实战案例] 【文末有测试代码】
  • 《XML Schema 字符串数据类型》
  • 【学生管理系统】环境搭建
  • 实测数据处理(CS算法处理:可斜视)——SAR成像算法系列(十一)
  • MVCC实现原理以及解决脏读、不可重复读、幻读问题
  • Docker添加镜像加速器
  • 短视频矩阵账号管理技术源码搭建详解,支持OEM
  • 生成对抗网络,边缘计算,知识图谱,解释性AI
  • 0基础学前端-----CSS DAY11
  • RK3566和Robo_C的EMC防护设计细节