k8s中pod组件简介

背景

k8s中pod是很重要的概念,他是k8s调度的最小单位,和我们以往的以docker容器为调度单位是不一样的,那么为什么k8s会以pod为调度单位而不是以更小的docker容器为调度单位呢?

pod组件

pod是一个逻辑的概念,其中可以包含多个docker容器组成一个小的服务单元,先来看一下pod的文件配置:

xml 复制代码
kind: Pod                                   --类型固定写pod
metadata :
  labels:
    - name: string                          --这个pod的label标识符,供外部其他组件选择pod时使用的
spec:
  containers :                              --这个pod中运行的docker容器数组,比如redis和http服务
    name : string                           --pod中比如运行的redis容器
    image : string                          --pod中比如运行的redis容器的镜像
   ports:
    containerPort: int                      --pod中比如运行的redis容器的端口号
    hostPort : int                          --pod中运行的redis容器对应的宿主机端口号
env:                                        --pod中的环境变量列表
   name: string
    value : string

k8s中pod是包含多个docker容器的一套套件,比如他会包含一个redis容器+日志采集容器的两个docker容器,这两个容器可以组成一个小的服务单元,而且本质上他们就是需要绑定在一起的服务单元,不需要把他们两个分开调度,所以在k8s看来,他调度的单位变成了调度一个小的功能服务单元,并且每个pod中都有一个特殊的Pause根容器,这个pause根容器的作用是为了让这个pod中的所有docker容器都可以共享统一网络,也就是pod中的所有容器拥有相同的ip地址,相同的主机名,对于外界来说,和这个pod内的任何一个docker容器通信都是一样的ip地址。

pod这种设计就能让k8s在调度的时候是以服务单元为单位调度的,这些pod里面的容器本来就是超亲密的关系,本来就不适合分开调度到不同的宿主机上面,所以k8s把他们捆绑起来一起调度很好的解决了这个问题

相关推荐
叮咚侠5 分钟前
将已创建的Elasticsearch 8.12.0的docker容器中的数据挂载到宿主机操作步骤
运维·elasticsearch·docker·容器·kibana
wuxingge23 分钟前
docker设置代理,通过代理服务器拉取镜像
docker·容器
SZ17011023129 分钟前
K8s 部署所需的配置文件
云原生·容器·kubernetes
小池先生34 分钟前
docker 安装gitlab
docker·容器·gitlab
赫尔·普莱蒂科萨·帕塔35 分钟前
Kurator 分布式云原生环境技术深度分析与实践指南
分布式·云原生
永亮同学39 分钟前
【探索实战】从“工具堆叠”到“平台治理”:基于 Kurator 构建统一分布式云原生管理底座的实践与思考
分布式·云原生
rchmin42 分钟前
云原生概念与技术详解
云原生
A-刘晨阳1 小时前
【探索实战】基于Kubernetes部署Kurator
运维·云原生·容器·kubernetes·kurator
晨欣1 小时前
[eBPF硬核] Gemini阿吉学习笔记:Tetragon企业版两类核心日志 & 冷热数据分流架构设计 & 学习资源推荐
笔记·学习·云原生·云安全·ebpf·谷歌gemini
橙 子_1 小时前
在 Amazon Bedrock 中推出 Claude Sonnet 4.5:Anthropic 最智能的模型,最适合编码和复杂代理
人工智能·python·云原生·html