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

相关推荐
❀͜͡傀儡师2 小时前
Docker部署搜索引擎SearXNG
运维·docker·容器·searxng
泡沫冰@2 小时前
K8S集群管理(3)
云原生·容器·kubernetes
麦兜*2 小时前
MongoDB 常见错误解决方案:从连接失败到主从同步问题
java·数据库·spring boot·redis·mongodb·容器
LQ深蹲不写BUG4 小时前
微服务事务管理利器:Seata 核心原理与实践指南
微服务·云原生·架构
nathan05294 小时前
Kubernetes 实战练习指南
云原生·容器·kubernetes
無名之輩5 小时前
Nvidia Device Plugin入门二之envvar策略
kubernetes
云和数据.ChenGuang7 小时前
微服务技术栈
微服务·云原生·架构
syty20207 小时前
K8s是什么
容器·kubernetes·dubbo
江团1io08 小时前
微服务雪崩问题与系统性防御方案
微服务·云原生·架构
Evan Wang9 小时前
使用Terraform管理阿里云基础设施
阿里云·云原生·terraform