k8s术语之Replication Controller

Replication Controller 在kubernetes中简称RC,它其实是定义了一个期望的场景,即声明某种Pod的副本数量在任意时刻都符合某个预期值,包括一下几个值:

1.Pod期待的副本数(replicas)

2.用于筛选目标Pod的Lable Selector

3.当Pod的副本数量小于预期数量时,用于创建新的Pod的模板(template)

当我们定义了一个RC并提交到kubernetes后,Master节点上的Controller Manager组件就得带通知,定期巡检检测中当前存活的目标Pod,并确保目标Pod实例的梳理刚好等于replicas的值,如果多于这个值,系统就会停掉一些pod,少之则创建。可以说,通过RC,kubernetes实现用户应用集群的高可用性,减少了手工运维操作

通过RC,可动态进行Pod实例数的缩放,kubectl scale命令为我们提供了这一功能

kubectl scale rc redis-slave --replicas=3

需要注意的是,删除RC并不会影响通过该RC已经创建好的Pod,为了删除所有Pod,可用通过设置replicas的值为0,然后更新该RC.另外Kubectl提供了stop和delete命令来一次性删除RC和RC控制的所有Pod

RC也提供用户应用平滑升级的功能,比如当前系统中有10个旧版本的Pod需要更新到新版,最好的方式是每次停止一个旧版本的Pod,就创建一个新版本的Pod,几分钟后当所有的Pod都是新版本时升级完成,用户不会感受到业务有任何影响,这种在kubernetes中被称作"滚动升级"

扩展和缩减

将replicas修改为5

kubectl apply -f rctest.yaml

kubectl get pod -o wide

相关推荐
狂团商城小师妹30 分钟前
JAVA露营基地预约户外露营预约下单系统小程序
java·开发语言·微信小程序·小程序
yujkss1 小时前
23种设计模式之【状态机模式】-核心原理与 Java实践
java·ui·设计模式
Lin_Aries_04212 小时前
容器化 Flask 应用程序
linux·后端·python·docker·容器·flask
无名指的等待7122 小时前
Redisson的Lock和TryLock的区别
java·开发语言·数据库
new_daimond2 小时前
Apache Shiro 技术详解
java·apache
yuriy.wang3 小时前
Spring IOC源码篇六 核心方法obtainFreshBeanFactory.parseCustomElement
java·后端·spring
.鸣3 小时前
idea学习日记10: 字符串相关类的底层原理
java·学习
在未来等你3 小时前
Kafka面试精讲 Day 24:Spring Kafka开发实战
java·spring boot·面试·kafka·消息队列·spring kafka·@kafkalistener
Lin_Aries_04213 小时前
通过配置 GitLab 自动触发项目自动化构建与部署
运维·docker·容器·自动化·云计算·gitlab
尘埃不入你眼眸3 小时前
Docker操作命令
运维·docker·容器