kubernetes 控制器 Dockerfile

在 Kubernetes 中,控制器被用来监控集群的公共状态,并将当前状态转变为预先设置的期望状态。

作为设计原则之一,Kubernetes 使用了很多控制器,每个控制器管理着集群状态的一个特定方面。

1.ReplicaSet

ReplicationController 用来确保在任何时候都有特定数量的 Pod 副本处于运行状态。换句话说, ReplicationController 能够确保一个 Pod 或一组同类的 Pod 总是可用的。

ReplicaSet 的目的是维护一组在任何时候都处于运行状态的 Pod 副本的稳定集合。因此,它通常用来保证给定数量的、完全相同的 Pod 的可用性。推荐使用配置了 ReplicaSet 的 Deployment 来 建立副本管理机制。
使用 nginx 镜像创建具有 3 个 pod 的 RS,并分配合适的标签:

删除的 Pod 消失了,但马上又有一个新的 Pod 被自动创建出来,总数依然维持在 3 个。这就是 ReplicaSet 在背后默默工作,保证了业务的连续性。

2.Deployment

ReplicaSet 确保了任何时间都有指定数量的 Pod 副本在运行。Deployment 是一个更高级的概念,它可以管理 ReplicaSet,并向 Pod 提供声明式的更新以及许多其它有用的功能。生产上,建议使用 Deployment 而不是直接使用 ReplicaSet 来部署应用,除非需要自定义更新业务流程或根本不需要更新。

示例,使用 nginx 镜像创建具有 3 个副本的 Deployment,并分配合适的属性。


deployment 管理了一个 RS,而 RS 又实现了 3 个 pod.

3.更新****Deployment

将 deployment 的镜像更改一次:

Deployment 并没有直接修改旧的 Pod,而是通过"新建新 RS -> 逐步起新 -> 逐步杀旧 -> 最终切换"的方式,保证了服务在升级过程中始终有可用的 Pod 在运行,从而实现了零停机更新。

发现更新过后多了一个 replicaset,新创建了三个 nginx 容器

4.回退Deployment

如果更新时将镜像名称写错,比如 nginx:1.161,而不是 nginx:1.16.1,就会导致永远无法更新成功,这个时候就需要进行回退操作。


查看历史更新版本:


查看历史更新版本 3 的详细信息:

回退到上一个正确版本 2:

5 .伸缩****Deployment

kubectl scale deployments/nginx-deployment --replicas=5

6.DaemonSet

DaemonSet 控制器能确保在全部(或者某些)节点上各运行一个 Pod 的副本。当有新节点加入集群时,也会为新节点启动一个 Pod,当有节点从集群移除时,这些 Pod 也会被回收。删除DaemonSet 将会删除它创建的所有 Pod。

DaemonSet 的一些典型用途:

  1. 在每个节点上运行集群守护进程。

  2. 在每个节点上运行日志收集守护进程。

  3. 在每个节点上运行监控守护进程。

使用 busybox 镜像,在每一个节点上都运行一个 Pod。

7.StatefulSet

StatefulSet 控制器用来管理基于相同容器规约的一组 Pod。但和 Deployment 不同的是,

StatefulSet 为它的每个 Pod 维护了一个有粘性的****ID。这些 Pod 是基于相同的规约来创建的,但是不能相互替换:无论怎么调度,每个 Pod 都有一个永久不变的 ID。

StatefulSets 非常适合于需要满足以下一个或多个需求的应用程序:

  1. 稳定的、唯一的网络标识符。

  2. 稳定的、持久的存储。

  3. 有序的、优雅的部署和缩放。

  4. 有序的、自动的滚动更新。

使用 nginx 镜像,创建一个副本数为 3 的有状态应用,并挂载本地目录到容器中。

8.JobCronJob

9. Dockerfile

Dockerfile 其实就是制作容器镜像(比如你用的 nginx)的"自动化配方"或"施工蓝图"

Kubernetes 负责调度和运行 Pod,而 Pod 里面跑的容器是从哪里来的呢?就是通过 Dockerfile 一行行指令构建出来的。它是一个纯文本文件,里面包含了一系列指令,告诉 Docker 引擎如何从零开始打包出一个包含你应用程序的镜像。

相关推荐
hj2862511 天前
Linux 磁盘管理 + 文件系统 + LVM 笔记整理
linux·运维
万里侯1 天前
Kubernetes Operator模式:自动化运维的高级实践
微服务·容器·k8s
Bert.Cai1 天前
Linux let命令详解
linux·运维·服务器
枕星而眠1 天前
Linux 线程:原理、属性、实战与面试避坑
linux·运维·c语言·面试
晚风予卿云月1 天前
【Linux】环境变量概念、作用、配置与修改详解
linux·运维·服务器·环境变量
~黄夫人~1 天前
零基础速通|Windows&Linux 常用命令行对照表大全
linux·运维·windows·笔记·备忘录·整理表格
benjiangliu1 天前
LINUX系统-17-EXT系列文件系统(二)
linux·运维·服务器
杨云龙UP1 天前
Linux 根分区被日志吃满?一次 58G Broker 日志清理实战_2026-05-20
linux·运维·服务器·数据库·hdfs·apache
络合白泽1 天前
Debian 13 + NVIDIA Optimus 笔记本:从零配置 Wayland Explicit Sync 完整指南
运维·debian