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

相关推荐
亚空间仓鼠9 小时前
Docker容器化高可用架构部署方案(十三)
docker·容器·架构
米高梅狮子10 小时前
01.mysql的备份与恢复
运维·数据库·mysql·docker·容器·kubernetes·github
云游牧者11 小时前
K8S存储体系全解-从PV-PVC-SC到StatefulSet持久化实战
云原生·容器·kubernetes·pvc·pv·sc·进阶存储卷
古城小栈11 小时前
K8s 认证、授权 系统
云原生·容器·kubernetes
码点滴11 小时前
K8s 节点“半死“状态如何自动愈合?AI Agent 构建智能自愈与健康量化体系
人工智能·容器·kubernetes
姚不倒12 小时前
Go语言实战:多态文件存储系统(接口、错误处理、panic/recover)
云原生·golang
木雷坞12 小时前
csdn-enterpriseGitLab Runner docker pull 慢:并行流水线镜像拉取排查
运维·docker·容器·gitlab
sbjdhjd12 小时前
02 下 | Kubernetes Pod 实战实验完全解析
linux·运维·云原生·kubernetes·podman·kubelet·kubeless
切糕师学AI12 小时前
Envoy 详解:云原生时代的高性能网络代理
网络·云原生·istio·网络代理·envoy·sidecar·网格服务