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把他们捆绑起来一起调度很好的解决了这个问题

相关推荐
CodeMartain3 小时前
Dify Windows 原生部署(无 Docker、纯本地)
运维·docker·容器
牛奶咖啡134 小时前
k8s容器编排技术实践——使用containerd作为容器运行时部署k8s集群
kubernetes·k8s的安装部署·开启系统的ipvs支持·安装containerd·containerd配置加速器·安装k8s的工具·安装calico网络插件
万里侯4 小时前
云原生数据备份与恢复:保障数据安全的最佳实践
微服务·容器·k8s
llrraa20105 小时前
配置docker国内镜像源
运维·docker·容器
阿里云云原生5 小时前
阿里云 STAROps 全域智能运维平台发布!从“被动救火”到“主动自治”
云原生
2301_780789666 小时前
手游遇到攻击为什么要用SDK游戏盾手游遇到攻击为什么要用 SDK 游戏盾?
安全·web安全·游戏·架构·kubernetes·ddos
35岁程序员的自救之路6 小时前
AiBBS - 面向下一个十年的AI + 云原生社区系统
人工智能·云原生
珂玥c7 小时前
k8s集群ingress碎碎念
云原生·容器·kubernetes
佳杰云星7 小时前
如何给大模型集群选“大脑”?智算调度与管理平台 10 维选型指南(附选型评分表)
人工智能·kubernetes·大模型·云计算·gpu·算力调度·智算中心
比特森林探险记9 小时前
context 在 gRPC / Gin / K8s 中的实战
容器·kubernetes·gin