k8s中pod详细

1.每个pod可以包含一个或多个容器 容器分为俩类

用户程序所在的容器,数量可多可少

Pause容器,每个pod都会有一个根容器,作用有俩个:

可以以它为依据,评估整个pod的健康状态

可以在根容器上设置IP,其他容器都以此IP 来实现Pod内部的网路通信。

pod定义

资源清单(yaml配置)

查询命令:kubectl explain pod

查看子属性(二级属性):kubectl explanin pod.metadata

基本配置

imagePullPolicy镜像拉取策略,k8s支持配置三种拉取策略:

Always:总是从远程仓库拉取镜像(一直用远程的)

IfNotPresent:本地有就用本地的 没有就拉取远程的

Never:只使用本地镜像,从不去远程仓库拉取,本地没有就报错

注意:如果nginx:laster版本为laster 则一直在远程仓库拉取

如果为具体版本 默认策略为IfNotPresent

启动命令:

busy不是一个程序 而是一个工具类的集合,k8s集群启动管理后,它会自动关闭。解决方法是让其一直运行,这里就用到了command配置

pod.spec.containers.env 环境变量

端口设置

kubectl explain pod.spec.containers.ports

资源配额

容器中的程序要运行 肯定要占用一定资源, 比如cpu和内存等,如果不对某个容器资源做限制,那么它可能就会吃掉大量资源,导致其他容器无法运行,所有k8s对内存和cpu资源进行配额的 机制通过resources实现,俩个子选项

limits:用于限制运行时容器的最大占用资源,当容器占用资源超过limits时会被终止,并进行重启

requests:用于设置容器需要的最小资源,如果资源不够,容器将无法启动

CPU:core 可以为整数或小数

memory:内存大小,可以使用Gi,Mi,G,M等形式

相关推荐
李匠20247 小时前
C++GO语言微服务之Dockerfile && docker-compose②
c++·容器
斤斤计较8 小时前
Docker 环境安装(2025最新版)
运维·docker·容器
小锋学长生活大爆炸8 小时前
【教程】Docker方式本地部署Overleaf
运维·docker·容器
Hfc.8 小时前
ubuntu20.04系统搭建k8s1.28集群-docker作为容器运行时
ubuntu·kubernetes
欧先生^_^8 小时前
Docker 的各种网络模式
网络·docker·容器
开源架构师8 小时前
JVM 与云原生的完美融合:引领技术潮流
jvm·微服务·云原生·性能优化·serverless·内存管理·容器化
掘金者说8 小时前
docker系列-DockerDesktop报错信息(Windows Hypervisor is not present)
运维·docker·容器
金刚猿12 小时前
openfeign 拦截器实现微服务上下文打通
微服务·云原生·架构
lcw_lance12 小时前
技术中台-核心技术介绍(微服务、云原生、DevOps等)
微服务·云原生·devops
alden_ygq15 小时前
Kubernetes Horizontal Pod Autosscaler(HPA)核心机制解析
云原生·容器·kubernetes