Kubernetes 学习总结(39)—— Kubernetes 之 Pause 容器详解

一、概念和作用

在 Kubernetes 中,Pause 容器是一种特殊类型的容器,它的主要作用是充当依赖其他容器的容器,为其他容器提供一个可靠的、隔离的运行环境。 Pause 容器是一种轻量级的容器,它本身不包含任何业务逻辑,只是为其他容器提供一个稳定、可靠的运行环境。Pause 容器的实现基于 Docker 的 pause 镜像,可以在创建其他容器之前将其加载到 Pod 中,以确保 Pod 中的其他容器在 Pause 容器的基础上运行。Pause 容器的主要作用是为其他容器提供生命周期的隔离和协调。它可以帮助管理员确保 Pod 中各个容器的启动顺序和依赖关系,避免容器之间的相互干扰和冲突。同时,Pause 容器还可以为 Pod 中的容器提供一个稳定的网络环境,确保容器的网络连接可靠性。

二、使用场景

Pause 容器在 Kubernetes 中有多种使用场景。以下是几个常见的场景:

1、调度器

Pause 容器可以用于调度器的实现。管理员可以通过在 Pod 中添加一个 Pause 容器来确保 Pod 的各个容器按照一定的调度顺序启动。这有助于避免容器之间的竞争和冲突,提高整个集群的稳定性。

2、管理容器应用

Pause 容器可以用于管理容器应用。在一些复杂的容器应用中,通常需要多个容器相互配合工作。通过使用 Pause 容器,管理员可以确保这些容器之间的一致性和协调性,提高整个应用的管理效率和可靠性。

三、工作原理

Pause 容器在 Kubernetes 中的工作原理主要包括以下几个方面:

1、与 Kubernetes 其他组件的交互

Pause 容器作为 Pod 中的一个组件,与 Kubernetes 的其他组件(如 API 服务器、Controller Manager 等)进行交互。当 Pod 被创建时,API 服务器将 Pause 容器的配置信息存储在 etcd 中,并通知 Controller Manager 对 Pod 进行处理。Controller Manager 将 Pause 容器与 Pod 中的其他容器一起调度到节点上运行。

2、管理容器的生命周期

Pause 容器通过使用名为 “cri-pause” 的进程来管理其他容器的生命周期。当 Pod 中的其他容器启动时,cri-pause 进程会将这些容器的启动信息记录在特定的文件中。当 Pod 被删除时,cri-pause 进程会检测到该文件并停止记录,以确保 Pod 中的容器在 Pause 容器的基础上一致地执行生命周期操作。

3、实现容器之间的协调合作

Pause 容器还通过使用 cni 网络插件来实现容器之间的协调合作。当 Pod 中的其他容器启动时,cni 网络插件将为这些容器分配 IP 地址并设置网络连接。这确保了 Pod 中的各个容器可以互相通信,实现协调合作。

四、实战指南

在使用 Pause 容器时,以下是一些实战指南:

1、配置 Pause 容器

要使用 Pause 容器,管理员需要在 Pod 配置文件中添加一个 Pause 容器的定义。例如:

apiVersion: v1  
kind: Pod  
metadata:  name: mypod  
spec:  containers:  - name: mycontainer1  image: myimage1  - name: mycontainer2  image: myimage2  initContainers:  - name: pause  image: kubeadm/pause

在这个示例中,我们在 Pod 中定义了两个普通容器(mycontainer1 和 mycontainer2),并添加了一个名为 “pause” 的Pause容器。

2、注入指令到 Pause 容器

如果需要在 Pause 容器中注入指令,可以使用 “initContainer” 字段。例如,要在 Pause 容器中运行一个特定的脚本,可以将该脚本保存为一个文件,并在 Pod 配置文件中使用 “volumeMounts” 字段将其挂载到 Pause 容器中:

apiVersion: v1  
kind: Pod  
metadata:  name: mypod  
spec:  containers:  - name: mycontainer1  image: myimage1  - name: mycontainer2  image: myimage2  initContainers:  - name: pause  image: kubeadm/pause  volumeMounts:  - name: myvolume  mountPath: /usr/local/bin/myscript.sh # 将脚本挂载到指定路径下  volumes:  - name: myvolume  emptyDir: {} # 创建一个临时卷用于保存脚本文件

此时在创建的 Pod 中,可以通过在 Pause 容器中执行指定脚本实现注入指令的目的。需要注意的是,该脚本文件需要在创建 Pod 之前预先准备好。

3、配置网络连接

要确保 Pod 中的各个容器可以互相通信,可以使用 Kubernetes 的网络策略来配置网络连接。例如:yamlapiVersion: networking.k8s.io/v1beta1#PodNetworkIntentb3a8d8

4、配置资源限制和环境变量

除了上述的配置之外,还可以为 Pause 容器配置资源限制和环境变量。例如,可以使用以下字段来配置资源限制:这将会为 Pause 容器设置 CPU 和内存的限制。此外,还可以使用 “env” 字段来配置环境变量。例如:

env:  - name: MY_ENV_VAR  value: my_value

这将会为 Pause 容器设置一个名为 “MY_ENV_VAR” 的环境变量,其值为 “my_value”。

5、注意事项

在使用 Pause 容器时,需要注意以下几点:不要将业务逻辑放在 Pause 容器中,因为 Pause 容器只是为其他容器提供一个运行环境。确保 Pod 中的容器与 Pause 容器一起调度和升级,以保证一致性和稳定性。在配置 Pod 时,要充分考虑资源限制和环境变量的配置,以确保 Pod 的正常运行和管理。总之,Pause 容器是 Kubernetes 中一个非常实用的组件,它可以为其他容器提供一个稳定、可靠的运行环境,并帮助管理员实现容器的生命周期管理和协调。正确使用 Pause 容器可以有效地提高 Kubernetes 集群的管理效率和应用的可靠性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/114116.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

华为OD 磁盘容量排序(100分)【java】A卷+B卷

华为OD统一考试A卷+B卷 新题库说明 你收到的链接上面会标注A卷还是B卷。目前大部分收到的都是B卷。 B卷对应20022部分考题以及新出的题目,A卷对应的是新出的题目。 我将持续更新最新题目 获取更多免费题目可前往夸克网盘下载,请点击以下链接进入: 我用夸克网盘分享了「华为O…

自然语言处理---Transformer机制详解之BERT模型特点

1 BERT的优点和缺点 1.1 BERT的优点 通过预训练, 加上Fine-tunning, 在11项NLP任务上取得最优结果.BERT的根基源于Transformer, 相比传统RNN更加高效, 可以并行化处理同时能捕捉长距离的语义和结构依赖.BERT采用了Transformer架构中的Encoder模块, 不仅仅获得了真正意义上的b…

华为OD机试 - 代表团坐车 - 动态规划(Java 2023 B卷 200分)

目录 专栏导读一、题目描述二、输入描述三、输出描述四、解题思路五、Java算法源码六、效果展示1、输入2、输出3、说明 华为OD机试 2023B卷题库疯狂收录中,刷题点这里 专栏导读 本专栏收录于《华为OD机试(JAVA)真题(A卷B卷&#…

Ubuntu 22.04 中安装 fcitx5

Ubuntu 22.04 中安装 fcitx5 可以按照以下步骤进行: 添加 fcitx5 的 PPA 首先,添加 fcitx5 的官方 PPA: sudo add-apt-repository ppa:fcitx-team/fcitx5更新软件包列表 sudo apt update安装 fcitx5 sudo apt install fcitx5 fcitx5-conf…

信息学奥赛一本通1000:入门测试题目

1000:入门测试题目 时间限制: 1000 ms 内存限制: 32768 KB 提交数: 318392 通过数: 190210 【题目描述】 求两个整数的和。 【输入】 一行,两个用空格隔开的整数。 【输出】 两个整数的和。 【输入样例】 2 3 【输出样例】 5 思路&#…

Mysql表结构差异比较

1、背景 我们在开发过程中,大部分情况下都是好几个版本一起并行,有时候如果某个版本表结构改动较大,但是忘记了记录DDL脚本,这个时候需要人工去把新增或修改的DDL脚本整理出来(主要是为了解决 数据库新增字段&#xff…

高效表达三步

一、高效表达 高效表达定主题搭架子填素材 第一: 1个核心主题,让别人秒懂你的想法 (表达要定主题) 第二: 3种经典框架,帮你快速整理表达思路 第三: 2种表达素材,让发言更具说服力…

在 Python 中执行 Shell 命令并获取输出

在本文中,我们将学习如何借助 os.system() 从 Python 脚本执行 cmd 命令。 我们还将学习如何借助 Python 中的 subprocess 模块以更简单的方式从脚本执行 cmd 命令。 从 Python 脚本执行 CMD 命令并使用 os.system() 获取输出 我们出于不同目的在命令提示符或任何其…

JAVA IO-序列化与反序列化

1.注意: 输入和输出都是从程序的角度来说的。 字节流:一次读入或读出是8位二进制。 字符流:一次读入或读出是16位二进制。 字节流和字符流的原理是相同的,只不过处理的单位不同而已。后缀是Stream是字节流,而后缀是Rea…

可视化 | python可视化相关库梳理(自用)| pandas | Matplotlib | Seaborn | Pyecharts | Plotly

文章目录 📚Plotly🐇堆叠柱状图🐇环形图🐇散点图🐇漏斗图🐇桑基图🐇金字塔图🐇气泡图🐇面积图⭐️快速作图工具:plotly.express🐇树形图&#x1f…

正点原子嵌入式linux驱动开发——Linux中断

不管是单片机裸机实验还是Linux下的驱动实验,中断都是频繁使用的功能,在裸机中使用中断需要做一大堆的工作,比如配置寄存器,使能IRQ等等。但是Linux内核提供了完善的中断框架,只需要申请中断,然后注册中断处…

怎样修改ESP32的CPU主频

ESP32的主频默认设置为160mhz,但ESP32最高可以跑到240mhz, 修改方法: idf.py menuconfig --> Component config --> ESP System Settings --> CPU frequency 可以看到三个选项,80,160, 240&…

跟我一起写个虚拟机 .Net 7(四)- LC_3 解析实例

没想到这篇文章持续了这么久,越学越深,愣是又买了一本书《计算机系统概论》,当然,也看完了,受益匪浅。 系统化的学习才是正确的学习方式,我大学就没看到过这本书,如果早点看到,可能…

STM32F4之系统滴答定时器

一、系统滴答定时器概述 传统定时器:如手机闹钟,闹钟等就是一个简单地计数器。 定时器概念:由时钟源计数器计数值组成的计数单元。 系统嘀嗒定时器首先是存在于内核里,系统嘀嗒时钟假如用的是同一个内核那么里面相关的配置&…

Android问题笔记 - NoSuchmethodException: could not find Fragment constructor

点击跳转>Unity3D特效百例点击跳转>案例项目实战源码点击跳转>游戏脚本-辅助自动化点击跳转>Android控件全解手册点击跳转>Scratch编程案例点击跳转>软考全系列 👉关于作者 专注于Android/Unity和各种游戏开发技巧,以及各种资源分享&…

守护进程深度分析

思考 代码中创建的会话,如何关联控制终端? 新会话关联控制终端的方法 会话首进程成功打开终端设备 (设备打开前处于空闲状态) 1、关闭标准输入输出和标准错误输出2、将 stdin 关联到终端设备:STDIN_FILENO > 03、将 stdout 关联到终端设…

每日刷题|贪心算法初识

食用指南:本文为作者刷题中认为有必要记录的题目 推荐专栏:每日刷题 ♈️今日夜电波:悬溺—葛东琪 0:34 ━━━━━━️💟──────── 3:17 &#x1f…

idea中还原dont ask again

背景 在使用idea打开另外一个项目的时候,一不小心勾选为当前项目而且是不在下次询问,导致后面每次打开新的项目都会把当前项目关闭,如下图所示 下面我们就一起看一下如何把这个询问按钮还原回来 preferences/settings->Appearance&…

展馆导览系统之AR互动式导航与展品语音讲解应用

一、项目背景 随着科技的进步和人们对于文化、艺术、历史等方面需求的提升,展馆在人们的生活中扮演着越来越重要的角色。然而,传统的展馆导览方式,如纸质导览、人工讲解等,已无法满足参观者的多元化需求。为了提升参观者的体验&a…

vulnhub靶机Funbox11

下载地址:Funbox: Scriptkiddie ~ VulnHub 主机发现 arp-scan -l 目标192.168.21.164 端口扫描 nmap --min-rate 1000 -p- 192.168.21.164 端口好多处理一下吧 nmap --min-rate 1000 -p- 192.168.21.164 |grep open |awk -F / {print $1} |tr \n , 端口服务版本…