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

相关推荐
JellyfishMIX3 小时前
k8s 容器 cpu 概念
docker·容器·kubernetes
BIGmustang5 小时前
基于rancher-rke部署 k8s集群
容器·kubernetes·rancher
Cat_Rocky6 小时前
通过k8s实现单pod部署
java·容器·kubernetes
运维全栈笔记6 小时前
K8S部署WordPress+MySQL:模块化YAML配置详解
服务器·mysql·docker·云原生·容器·kubernetes·服务发现
眷蓝天7 小时前
k8s-pod资源对象实验
云原生·容器·kubernetes·pod资源对象
木雷坞7 小时前
Physical AI 数据工厂怎么落地?先把 CUDA、K8s、Quay 镜像拉取稳定下来
人工智能·容器·kubernetes
剩下了什么9 小时前
docker-compose up -d --build 和 docker-compose up -d 和 docker-compose build 区别
docker·容器·eureka
两点王爷10 小时前
使用命令行备份/还原docker运行的数据库 (MySQL、PostgreSQL)
mysql·docker·容器
张青贤10 小时前
Docker Remote 未授权访问漏洞修复方法
运维·docker·容器
TE-茶叶蛋10 小时前
微服务下 DTO 设计核心原则
微服务·云原生·架构