k8s拉起一个pod底层是如何运行的

在Kubernetes中,当你尝试启动一个Pod时,底层的运行方式是由Kubelet服务来管理的。以下是Pod启动过程的简化概述:

  1. Kubernetes API Server接收到创建Pod的请求。

  2. API Server将Pod的元数据存储到etcd中,以便于Pod的调度和跟踪。

  3. Scheduler组件基于集群的当前状态(如节点的可用资源)来选择一个合适的节点来运行Pod。

  4. 选定的节点上的kubelet服务定时询问API Server关于Pod的信息,并监控其健康状态。

  5. kubelet通过Docker(或其他容器运行时)来创建和启动容器。

实际的Pod运行代码通常涉及使用kubectl或其他Kubernetes管理工具与API Server交互来创建Pod资源对象。例如,以下是一个简单的Pod定义示例(YAML格式):

apiVersion: v1

kind: Pod

metadata:

name: my-app-pod

labels:

app: my-app

spec:

containers:

  • name: my-app-container

image: my-app-image

ports:

  • containerPort: 80

你可以将这个YAML文件保存,然后使用以下命令来创建Pod:

kubectl apply -f my-app-pod.yaml

相关推荐
码农阿豪19 分钟前
一个浏览器多人用?Docker+Neko+cpolar实现跨网共享
运维·docker·容器
荣光波比24 分钟前
K8S(十)—— Kubernetes核心组件详解:Pod控制器与配置资源管理
java·容器·kubernetes
奋斗的蛋黄2 小时前
K8s 核心三组件:kubelet、kubeadm、kubectl 知识点梳理
云原生·容器·kubernetes
m0_579146653 小时前
docker desktop创建ollama容器端口绑定失败
运维·docker·容器
愚昧之山绝望之谷开悟之坡3 小时前
docker和docker compose离线安装-2-报错
运维·docker·容器
AAA小肥杨9 小时前
基于k8s的Python的分布式深度学习训练平台搭建简单实践
人工智能·分布式·python·ai·kubernetes·gpu
xiaogg367813 小时前
阿里云k8s1.33部署yaml和dockerfile配置文件
java·linux·kubernetes
2503_9301239313 小时前
Kubernetes (四)网络插件详解:Flannel 与 Calico 的原理、数据流向与实战对比
网络·容器·kubernetes
K_i13414 小时前
K8s 运维三大核心难题:DNS 故障、有状态存储、AI 赋能 SRE 解决方案
kubernetes
远向光17 小时前
k8s中的控制器
linux·容器·kubernetes