pod的拉取和重启策略
在Kubernetes中,Pod的拉取策略和重启策略可以通过YAML配置文件来定义。
Pod的拉取策略
Pod的拉取策略指的是Kubernetes在创建或重启Pod时,如何获取Pod所需的容器镜像。这个策略可以通过imagePullPolicy
字段在Pod的配置文件中进行定义。以下是imagePullPolicy
可以设置的三种策略值及其对应的行为:
- Always:这是默认值。无论本地是否存在所需的镜像,Kubernetes都会尝试从远程镜像仓库中拉取最新的镜像。这确保了Pod总是使用最新版本的镜像来启动容器。
- IfNotPresent:如果本地已经存在所需的镜像,Kubernetes将不会尝试从远程仓库拉取,而是直接使用本地镜像。如果本地不存在该镜像,Kubernetes会尝试从远程仓库拉取。这种策略可以减少不必要的网络请求和镜像拉取时间,特别是当镜像仓库位于网络延迟较高的地区时。
- Never:Kubernetes将不会尝试从远程仓库拉取镜像,仅使用本地已经存在的镜像。如果本地没有所需的镜像,Pod将无法启动,并会报告一个错误。这种策略通常用于确保Pod使用特定的本地镜像版本,或者当镜像已经以某种方式预先加载到节点上时。
下面是一个Pod配置YAML的例子,展示了如何设置镜像拉取策略:
apiVersion: v1
kind: Pod
metadata:
name: my-pod
spec:
containers:
- name: my-container
image: my-image:latest
imagePullPolicy: IfNotPresent # 可以是 Always, IfNotPresent, Never
在这个例子中,imagePullPolicy: IfNotPresent
意味着如果本地已经存在my-image:latest
这个镜像,则不会再去远程仓库拉取。
Pod的重启策略
Pod的重启策略可以通过restartPolicy
字段来定义,在Pod配置文件中,它有以下几个可选值:
Always
:当容器退出时,总是重启容器。这是默认的重启策略。OnFailure
:当容器以非零状态码退出时,重启容器。也就是说,如果容器正常退出(返回码为0),则不会重启。Never
:不论容器的退出状态码是什么,都不会重启容器。
下面是一个Pod配置YAML的例子,展示了如何设置重启策略:
apiVersion: v1
kind: Pod
metadata:
name: my-pod
spec:
containers:
- name: my-container
image: my-image:latest
restartPolicy: Always # 可以是 Always, OnFailure, Never
在这个例子中,restartPolicy: Always
意味着无论容器如何退出,都会立即重启容器。
请注意,对于由Deployment或ReplicaSet管理的Pod,Pod的重启策略通常会被忽略,因为Deployment或ReplicaSet控制器会负责维护Pod的期望状态。在这种情况下,Pod的重启策略实际上是由Deployment或ReplicaSet的更新策略来控制的。
如果你需要通过修改YAML文件来重启Pod,通常的做法是更新YAML文件中的某些字段(比如容器的镜像版本),然后应用更新,Kubernetes将检测到变更并相应地重启Pod。此外,也可以通过命令如kubectl replace --force -f xxx.yaml
来强制替换Pod配置,从而触发Pod的重启。
pod的拉取和重启策略的更多相关文章
- Kubernetes Pod 镜像拉取策略
Kubernetes Pod 镜像拉取策略 官方文档:https://kubernetes.io/docs/concepts/containers/images/ • IfNotPresent:默认值 ...
- Pod镜像拉取策略imagePullPolicy
默认值是IfNotPresent Always 总是拉取: 首先获取仓库镜像信息, 如果仓库中的镜像与本地不同,那么仓库中的镜像会被拉取并覆盖本地. 如果仓库中的镜像与本地一致,那么不会拉取镜像. 如 ...
- kubernetes配置secret拉取私仓镜像
2017.05.10 19:48* 字数 390 阅读 5216评论 0喜欢 8 对于公司内部的项目, 我们不可能使用公有开放的镜像仓库, 一般情况可能会花钱买docker私仓服务, 或者说自己在服务 ...
- kubernetes之pod生命周期,pod重启策略, 镜像拉取策略
pod声明周期(状态):pending , running, succeeded, failed, unknown 挂起(Pending):Pod 已被 Kubernetes 系统接受,但有一个或者多 ...
- kubernetes之镜像拉取策略ImagePullSecrets;
1.容器镜像是什么? 1.容器镜像(Container Image)是最终运行的软件: 2.容器镜像(最初为Docker镜像,现在叫OCI镜像更合适)是将软件打包的形式.但是容器镜像还可以携带额外的设 ...
- .net core i上 K8S(四).netcore程序的pod管理,重启策略与健康检查
上一章我们已经通过yaml文件将.netcore程序跑起来了,但还有一下细节问题可以分享给大家. 1.pod管理 1.1创建pod kubectl create -f netcore-pod.yaml ...
- 配置kuernetes集群pod拉取私有镜像仓库中的镜像
目录 1 背景说明 2 实现方法 3 具体实现 配置镜像仓库项目为公开类型(任何人可以访问) 配置docker-registry类型的secret(pod使用secret获取镜像认证) 通过账户名密码 ...
- Pod 生命周期和重启策略
Pod 在整个生命周期中被系统定义为各种状态,熟悉 Pod 的各种状态对于理解如何设置 Pod 的调度策略.重启策略是很有必要的. Pod 的状态 状态值 描述 Pending API Server ...
- kubernetes之基于ServiceAccount拉取私有镜像
前面可以通过ImagPullPolicy和ImageullSecrets指定下载镜像的策略,ServiceAccount也可以基于spec.imagePullSecret字段附带一个由下载镜像专用的S ...
- 配置 Containerd 在 harbor 私有仓库拉取镜像
官方文档地址:https://github.com/containerd/cri/blob/master/docs/registry.md 严格来说,这个具体可分为两部分 1.在k8s中使用Conta ...
随机推荐
- 用npm查看可安装的包版本
1.查看包版本命令 npm view less-loader versions
- LeetCode刷题日记 2020/03/26
题干 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc ...
- 三星发布990 EVO SSD:同时支持PCIe 4.0和PCIe 5.0
1月8日消息,三星发布了新款产品--990 EVO SSD,这是首款同时支持了PCIe 4.0 x4及PCIe 5.0 x2通道的SSD. 据了解,990 EVO面向中端市场,为2280 M.2规格, ...
- 架构设计脱胎换骨!英特尔酷睿Ultra深度解析
英特尔正式发布了第一代酷睿Ultra处理器平台,也就是首个基于Intel 4制程工艺(7nm)打造的移动级处理器平台,其核心代号为Meteor Lake,产品系列贴标设计也采用了全新方案. 同时在命名 ...
- mybatis SQL in() 为什么要在 mapper.xml里 用 foreach
结论: 若存在 in () 语句,要使用 #{} 预编译入参的方式,需要在 mapper.xml里 使用 foreach ======================================= ...
- 如何在Delphi TImageList 中使用 透明 png 图标
Query: "Embarcadero Delphi ImageList does not show transparent PNG icons correctly. How to fix ...
- NC214362 第k小
题目链接 题目 题目描述 有一个长度为n的数组,值为 a[i], 牛牛想找到数组中第 k 小的数.比如 1 2 2 3 4 6 中,第 3 小的数就是2. 牛牛觉得这个游戏太简单了,想加一点难度,现在 ...
- 深入 Nginx 之架构篇[转]
前言 最近在读 Nginx 相关的书籍,做一下读书笔记. Nginx 作为业界知名的高性能服务器,被广泛的应用.它的高性能正是由于其优秀的架构设计,其架构主要包括这几点:模块化设计.事件驱动架构.请求 ...
- mdbook安装使用实录
简介 mdbook是一个基于Rust的电子书系统,效果类似于gitbook.本人写图文文章一直都采用的印象笔记,但是写系列教程的情况不方便管理.因此引入mdBook,分享一下基本安装使用过程及遇到的问 ...
- win32 - 多字节下的中文字符打印到文本中
#include <Windows.h> #include <stdio.h> #include <io.h> #include <fcntl.h> # ...