概述

官网地址:https://kubernetes.io/zh-cn/docs/concepts/workloads/controllers/replicationcontroller/

ReplicationController 是一个比较原始的Pod控制器,已经被废弃,由ReplicaSet控制器替代,想要了解ReplicaSet可查看这篇文章:K8s新手系列之ReplicaSet资源

ReplicationController简称rc,称为副本控制器,其主要作用就是控制Pod副本数量的控制器。

ReplicationController 确保在任何时候都有特定数量的 Pod 副本处于运行状态。只要 ReplicationController 不删除,则指定的Pod数量会使用存活。

ReplicationController的作用

  • 副本管理:ReplicationController 的核心功能是保证在任何时候都有指定数量的 Pod 副本在运行。如果有 Pod 意外终止,ReplicationController 会自动创建新的 Pod 来替代它;如果 Pod 数量过多,它会删除多余的 Pod。

  • 滚动更新:在早期版本中,虽然 ReplicationController 本身不支持滚动更新,但可以通过创建新的 ReplicationController 并逐步减少旧的 ReplicationController 中的 Pod 数量来实现类似滚动更新的效果。

  • 集群扩容和缩容:用户可以通过修改 ReplicationController 中的副本数量来轻松地对应用进行扩容或缩容。

ReplicationController资源配置文件详解

可以通过kubectl explain rc查看创建ReplicationController需要的字段

示例:

[root@node01 ~]# kubectl explain rc
KIND: ReplicationController
VERSION: v1 DESCRIPTION:
ReplicationController represents the configuration of a replication
controller. # fileds字段中的内容已进行截取
FIELDS:
apiVersion <string> kind <string> metadata <Object> spec <Object> status <Object>

通过上述可以发现定义ReplicationController的资源文件和定义Pod一样,也需要apiVersion、kind、metadata、spec等字段。

但是spec字段中有三个字段,需要注意,分别是replicas、selector、template。如下:

[root@node01 ~]# kubectl explain rc.spec
KIND: ReplicationController
VERSION: v1 RESOURCE: spec <Object> DESCRIPTION:
Spec defines the specification of the desired behavior of the replication
controller. More info:
https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status ReplicationControllerSpec is the specification of a replication controller. FIELDS:
minReadySeconds <integer>
# minReadySeconds 规定了一个时间阈值,只有当 Pod 保持就绪状态的时间达到或者超过这个阈值,并且在此期间 Pod 内的任何容器都没有崩溃,这个 Pod 才会被视为可用。 replicas <integer>
# 定义Pod的副本数量 selector <map[string]string>
# 标签选择器,这里指定Pod定义的标签 template <Object>
# 定义Pod的模板

创建ReplicationController

这里我们创建三个Pod副本

示例:

# 定义rc清单文件
[root@node01 ~/rc]# cat rc-nginx.yaml
apiVersion: v1
kind: ReplicationController
metadata:
name: rc-nginx-1
namespace: default
labels:
app: rc-nginx
spec:
# 定义Pod的副本数量
replicas: 3
# 标签选择器,这里和Pod的Label保持一致
selector:
app: nginx
# 定义Pod的模板,只需要定义metadata和spec两个字段即可
template:
metadata:
name: pod-nginx
labels:
app: nginx
spec:
restartPolicy: Always
containers:
- name: nginx
image: nginx:latest
restartPolicy: Always # 创建rc
[root@node01 ~/rc]# kubectl apply -f rc-nginx.yaml
replicationcontroller/rc-nginx-1 created

查看ReplicationController和对应的Pod

查看ReplicationController

[root@node01 ~/rc]# kubectl get rc -o wide
NAME DESIRED CURRENT READY AGE CONTAINERS IMAGES SELECTOR
rc-nginx-1 3 3 3 45s nginx nginx:latest app=nginx

查看对应Pod

[root@node01 ~/rc]# kubectl get po | grep rc-nginx
rc-nginx-1-8ptc7 1/1 Running 0 2m38s
rc-nginx-1-8xvbr 1/1 Running 0 2m38s
rc-nginx-1-lk45f 1/1 Running 0 2m38s

验证ReplicationController的副本管理

ReplicationController 的核心功能是保证在任何时候都有指定数量的 Pod 副本在运行。如果有 Pod 意外终止,ReplicationController 会自动创建新的 Pod 来替代它;如果 Pod 数量过多,它会删除多余的 Pod。

当我们删除创建好的Pod时,ReplicationController会发生什么呢?

# 删除上面创建Pod
[root@node01 ~/rc]# kubectl delete po rc-nginx-1-8ptc7 rc-nginx-1-8xvbr rc-nginx-1-lk45f
pod "rc-nginx-1-8ptc7" deleted
pod "rc-nginx-1-8xvbr" deleted
pod "rc-nginx-1-lk45f" deleted # 查看rc,发现其副本数量还是三个
[root@node01 ~/rc]# kubectl get rc
NAME DESIRED CURRENT READY AGE
rc-nginx-1 3 3 3 6m11s # 查看Pod,发现对应的Pod还是三个
[root@node01 ~/rc]# kubectl get po | grep rc-nginx
rc-nginx-1-g6qvg 1/1 Running 0 18s
rc-nginx-1-gwzd4 1/1 Running 0 18s
rc-nginx-1-x2rqm 1/1 Running 0 19s

通过上述验证,当Pod被意外终止时,ReplicationController会自动创建它

验证ReplicationController的扩缩容

验证扩容

我们将副本数量调整成5,看看会发生什么?

[root@node01 ~/rc]# cat rc-nginx.yaml
apiVersion: v1
kind: ReplicationController
metadata:
name: rc-nginx-1
namespace: default
labels:
app: rc-nginx
spec:
# 将副本数量调整成5
replicas: 5
selector:
app: nginx
template:
metadata:
name: pod-nginx
labels:
app: nginx
spec:
restartPolicy: Always
containers:
- name: nginx
image: nginx:latest
restartPolicy: Always # 重新应用它
[root@node01 ~/rc]# kubectl apply -f rc-nginx.yaml
replicationcontroller/rc-nginx-1 configured

查看一下:

# 查看rc
[root@node01 ~/rc]# kubectl get rc
NAME DESIRED CURRENT READY AGE
rc-nginx-1 5 5 5 11m
# 查看pod
[root@node01 ~/rc]# kubectl get po | grep rc-nginx
NAME READY STATUS RESTARTS AGE
rc-nginx-1-7dnlv 1/1 Running 0 87s
rc-nginx-1-dsr6h 1/1 Running 0 87s
rc-nginx-1-g6qvg 1/1 Running 0 6m55s
rc-nginx-1-gwzd4 1/1 Running 0 6m55s
rc-nginx-1-x2rqm 1/1 Running 0 6m56s

通过上述发现Pod副本数量由3个变成了5个,查看AGE字段,发现有两个Pod是新建的状态。

验证缩容

同理,我们将副本数量调整成1,看看会发生什么?

[root@node01 ~/rc]# cat rc-nginx.yaml
apiVersion: v1
kind: ReplicationController
metadata:
name: rc-nginx-1
namespace: default
labels:
app: rc-nginx
spec:
# 将副本数量调整成1
replicas: 1
selector:
app: nginx
template:
metadata:
name: pod-nginx
labels:
app: nginx
spec:
restartPolicy: Always
containers:
- name: nginx
image: nginx:latest
restartPolicy: Always # 重新应用它
[root@node01 ~/rc]# kubectl apply -f rc-nginx.yaml
replicationcontroller/rc-nginx-1 configured

查看一下

# 查看rc
[root@node01 ~/rc]# kubectl get rc
NAME DESIRED CURRENT READY AGE
rc-nginx-1 1 1 1 15m
# 查看Pod
[root@node01 ~/rc]# kubectl get po | grep rc-nginx
rc-nginx-1-x2rqm 1/1 Running 0 9m32s

通过上述发现,Pod数量由5个缩减成了1个

验证ReplicationController的滚动更新

早期版本中,虽然 ReplicationController 本身不支持滚动更新,但可以通过创建新的 ReplicationController 并逐步减少旧的 ReplicationController 中的 Pod 数量来实现类似滚动更新的效果。

示例:将上述案例中的Pod的镜像替换成tomcat

[root@node01 ~/rc]# cat rc-nginx.yaml
apiVersion: v1
kind: ReplicationController
metadata:
name: rc-nginx-1
namespace: default
labels:
app: rc-nginx
spec:
# 将副本数量调整成5
replicas: 5
selector:
app: nginx
template:
metadata:
name: pod-nginx
labels:
app: nginx
spec:
restartPolicy: Always
containers:
- name: nginx
# 将镜像替换成tomcat
image: tomcat:latest
restartPolicy: Always # 重新应用它
[root@node01 ~/rc]# kubectl apply -f rc-nginx.yaml
replicationcontroller/rc-nginx-1 configured

查看Pod变化

# 第一次查看
[root@node01 ~/rc]# kubectl get po
NAME READY STATUS RESTARTS AGE
rc-nginx-1-gvdwl 0/1 ContainerCreating 0 2s
rc-nginx-1-rtdlw 0/1 ContainerCreating 0 2s
rc-nginx-1-vzfb2 0/1 ContainerCreating 0 2s
rc-nginx-1-x2rqm 1/1 Running 0 15m
rc-nginx-1-zwms9 0/1 ContainerCreating 0 2s # 最后查看
[root@node01 ~/rc]# kubectl get po
NAME READY STATUS RESTARTS AGE
pod-evc-secret-1 0/1 CrashLoopBackOff 68 (3m39s ago) 21h
rc-nginx-1-gvdwl 1/1 Running 0 71s
rc-nginx-1-rtdlw 1/1 Running 0 71s
rc-nginx-1-vzfb2 1/1 Running 0 71s
rc-nginx-1-wscvf 0/1 ContainerCreating 0 3s
rc-nginx-1-zwms9 1/1 Running 0 71s

发现Pod在逐步替换,可以访问一下对应Pod试一下,发现返回的内容是Tomcat的内容

滚动更新的原理

滚动更新的核心目标是在不中断服务的前提下,逐步将旧版本的应用替换为新版本。在使用 ReplicationController 时,这一过程主要通过以下几个步骤完成:

  1. 创建新版本的 ReplicationController

    当需要对应用进行更新时,首先要创建一个新的 ReplicationController,其配置与旧的 ReplicationController 基本相同,但使用了新版本的应用镜像。新的 ReplicationController 初始的副本数量通常设置为 0。

  2. 逐步增加新版本的 Pod 副本数量

    在创建好新的 ReplicationController 后,逐步增加其管理的 Pod 副本数量。每次增加少量副本(例如每次增加 1 个),这样可以确保新的 Pod 有足够的时间启动并稳定运行,避免一次性创建大量新 Pod 导致资源紧张或服务不稳定。

  3. 逐步减少旧版本的 Pod 副本数量

    在增加新版本 Pod 副本数量的同时,逐步减少旧的 ReplicationController 管理的 Pod 副本数量。同样,每次减少少量副本,以保证服务的连续性。

  4. 重复步骤 2 和 3

    不断重复增加新版本 Pod 副本数量和减少旧版本 Pod 副本数量的过程,直到旧版本的 ReplicationController 管理的 Pod 副本数量降为 0,而新版本的 ReplicationController 管理的 Pod 副本数量达到预期值。

管理ReplicationController

查看ReplicationController

语法:

kubectl get rc <rc-name> -n <namespace-name>

示例:

[root@node01 ~/rc]# kubectl get rc
NAME DESIRED CURRENT READY AGE
rc-nginx-1 5 5 5 29m

修改ReplicationController

由两种方式,一种是通过kubectl edit rc <rc-name>来进行修改,会打开一个类似vim的界面,修改其对应的值即可,最后wq保存即可应用你的配置

第二种方式则是修改对应的资源文件,最后使用kubectl apply -f <file>即可

删除ReplicationController

删除ReplicationController时会删除所有对应的Pod!!!

语法:

kubectl delete rc <rc-name> -n <namespace-name>

K8s新手系列之ReplicationController资源的更多相关文章

  1. k8s入门系列之guestbook快速部署

    k8s集群以及一些扩展插件已经安装完毕,本篇文章介绍一下如何在k8s集群上快速部署guestbook应用. •实验环境为集群:master(1)+node(4),详细内容参考<k8s入门系列之集 ...

  2. k8s入门系列之扩展组件(一)DNS安装篇

    DNS (domain name system),提供域名解析服务,解决了难于记忆的IP地址问题,以更人性可读可记忆可标识的方式映射对应IP地址. Cluster DNS扩展插件用于支持k8s集群系统 ...

  3. 【原】Android热更新开源项目Tinker源码解析系列之二:资源文件热更新

    上一篇文章介绍了Dex文件的热更新流程,本文将会分析Tinker中对资源文件的热更新流程. 同Dex,资源文件的热更新同样包括三个部分:资源补丁生成,资源补丁合成及资源补丁加载. 本系列将从以下三个方 ...

  4. k8s入门系列之集群安装篇

    关于kubernetes组件的详解介绍,请阅读上一篇文章<k8s入门系列之介绍篇> Kubernetes集群安装部署 •Kubernetes集群组件: - etcd 一个高可用的K/V键值 ...

  5. Github干货系列:C++资源集合-

    Awesome CPP,这又是一个 Awesome XXX 系列的资源整理,由 fffaraz 发起和维护.内容包括:标准库.Web应用框架.人工智能.数据库.图片处理.机器学习.日志.代码分析等. ...

  6. FrameBuffer系列 之 一点资源

    Iamonlyme的FrameBuffer编程实例http://download.csdn.net/detail/iamonlyme/6512955 light588的通过framebuffer直接写 ...

  7. Android新手系列教程(申明:来源于网络)

    Android新手系列教程(申明:来源于网络) 地址:http://blog.csdn.net/column/details/androidcoder666.html

  8. k8s 入门系列之集群安装篇

    关于kubernetes组件的详解介绍,请阅读上一篇文章<k8s入门系列之介绍篇> Kubernetes集群安装部署 •Kubernetes集群组件: - etcd 一个高可用的K/V键值 ...

  9. SignalR新手系列教程详解总结(转)

    SignalR新手系列教程详解总结 GlobalHost.ConnectionManager.GetHubContext<TodoListHub>() .Clients.Clients(l ...

  10. 容器编排系统K8s之ConfigMap、Secret资源

    前文我们了解了k8s上的pv/pvc/sc资源的使用和相关说明,回顾请参考:https://www.cnblogs.com/qiuhom-1874/p/14188621.html:今天我们主要来聊一下 ...

随机推荐

  1. [SDOI2015] 序列统计 题解

    乘法并不容易用 FFT 或 NTT 维护,考虑在模意义下化乘为加. 化乘为加主要有两种方法:\(\log\) 和 \(\gamma\)(指标),由于在取模意义下,所以使用后者. 那剩下的部分就是快速幂 ...

  2. CF57C Array 题解

    发现单调不降序列反过来就是单调不增序列,只需考虑单调不降序列即可. 假如将问题转化为:初始为 \(1\),一共有 \(n+1\) 个位置,有 \(n-1\) 次增加答案的机会,每个位置可以拥有多次增加 ...

  3. led色块是什么,bin指值是什么

    色块其实就是色温的区域范围. LED的色温按标准是分段的, 既然是分段,就有一个最大值和最小值,在色坐标系中是一个,X和Y的坐标对应的也就有一个最大值和最小值,这样一个色温段就是以小块的区域,即所谓的 ...

  4. vscode开发小程序2

    开发tab: 1.下载阿里图标到新建文件夹icons里面 2.在app.json里面的"windows"同层下设置tab: 默认样式的设置:小程序中不识别通配符*! 1. 2.查看 ...

  5. ADF - [02] 概念

    题记部分 001 || 管道和活动 一个数据工厂可以有一个或多个管道(Pipeline).管道是共同执行一项任务的活动的逻辑分组.管道可以包含一组活动(Activity),这些活动引入和清除日志数据, ...

  6. Jenkins - [02] 安装部署

    题记部分 一.Jenkins是什么   Jenkins,原名Hudson,2011年改为现在的名字,它是一个开源的实现持续集成的软件工具. 官网:https://www.jenkins.io/ 官网: ...

  7. Shell - 脚本案例

    题记部分 一.节点状态监控脚本(nodeStatusCheck.sh) [脚本名称]nodeStatusCheck.sh [监控规则]通过ping的方式监控集群节点状态,检查节点是否失联 [实现方式] ...

  8. 自动化平台-环境搭建2-cmd 下mysql 卸载命令

    "" net stop mysql sc delete mysql rd /s /q "C:\Program Files\MySQL" rd /s /q &qu ...

  9. 【Unit4】UML解析器(模型化设计)-作业总结 & 【BUAA-OO】课程总结

    第四单元作业总结 1.题目概述 UML类图建模与查询(8) + UML顺序图/状态图建模与查询(3+3) + 模型错误检查(9),三次迭代共23条命令 2.构架设计 一开始以为和第三单元差不多,稍微用 ...

  10. rust学习笔记(5)

    函数 定义为 fn is_divisible_by(lhs: u32, rhs: u32) -> bool { 使用 -> 指向返回的类型 函数定义的位置没有限制 method 针对结构体 ...