kubernets之Replication Controller
一 Replication Controller的介绍
pod可能会由于各种原因消失和多出来,例如node节点去除集群或者人为的手工创建,所以为了方便和管理pod的数量,k8s里面
的另外一种资源就应运而生,Replication Controller,它能够管理特定的pod的标签,使其动态保持一个数量,少了就会去创建,多了就会删除集群中的pod
始终保持集群中pod数量是一个自己定义的数量
二 Replication Controller的组成(后面部分都简称RC)
RC由三部分组成
- label selector 用于确定RC能够控制的pod的标签的范围
- replica count 副本个数,指定运行容器的数量
- pod template pod的模板,用于创建新的pod副本
三 以yaml的形式创建一个RC
3.1 配置文件内容如下
[root@node01 Chapter04]# cat kubia-rc.yaml
apiVersion: v1
kind: ReplicationController
metadata:
name: kubia
spec:
replicas: 3
selector:
app: kubia
template:
metadata:
labels:
app: kubia
spec:
containers:
- name: kubia
image: luksa/kubia
ports:
- containerPort: 8080
3.2 创建RC
[root@node01 Chapter04]# k create -f kubia-rc.yaml
replicationcontroller/kubia created
[root@node01 Chapter04]# k get rc
NAME DESIRED CURRENT READY AGE
kubia 3 3 2 9s
[root@node01 Chapter04]# k get po
NAME READY STATUS RESTARTS AGE
kubia-cc6dg 1/1 Running 0 27s
kubia-dsc2x 1/1 Running 0 27s
kubia-liveness 1/1 Running 24 94m
kubia-liveness-delay 1/1 Running 17 64m
kubia-vz52m 1/1 Running 0 27s
3.3 经由RC管控的pod在被删除某个副本之后,RC会感知到数量已经不符合预期,会重新去拉取镜像创建pod,红色的是刚刚由RC最新创建的
[root@node01 Chapter04]# k get po
NAME READY STATUS RESTARTS AGE
kubia-cc6dg 1/1 Running 0 6m55s
kubia-dsc2x 1/1 Running 0 6m55s
kubia-vz52m 1/1 Running 0 6m55s [root@node01 Chapter04]# k delete po kubia-cc6dg
pod "kubia-cc6dg" deleted [root@node01 Chapter04]# k get po
NAME READY STATUS RESTARTS AGE
kubia-dsc2x 1/1 Running 0 8m22s
kubia-qgxvw 1/1 Running 0 80s
kubia-vz52m 1/1 Running 0 8m22s
3.4 RC完成通过标签来管控pod,也可以通过修改pod里面的标签,从而脱离RC的管控,甚至将pod从一个RC移动至另一个RC
[root@node01 Chapter04]# k get po --show-labels
NAME READY STATUS RESTARTS AGE LABELS
kubia-dsc2x 1/1 Running 0 11m app=kubia
kubia-qgxvw 1/1 Running 0 4m49s app=kubia
kubia-vz52m 1/1 Running 0 11m app=kubia
[root@node01 Chapter04]# k label po kubia-qgxvw type=docker
pod/kubia-qgxvw labeled
[root@node01 Chapter04]# k get po --show-labels
NAME READY STATUS RESTARTS AGE LABELS
kubia-dsc2x 1/1 Running 0 12m app=kubia
kubia-qgxvw 1/1 Running 0 5m39s app=kubia,type=docker
kubia-vz52m 1/1 Running 0 12m app=kubia
[root@node01 Chapter04]# k label po kubia-vz52m app=k8s --overwrite
pod/kubia-vz52m labeled
[root@node01 Chapter04]# k get po
NAME READY STATUS RESTARTS AGE
kubia-dsc2x 1/1 Running 0 13m
kubia-jqr8m 0/1 ContainerCreating 0 5s
kubia-qgxvw 1/1 Running 0 6m9s
kubia-vz52m 1/1 Running 0 13m
注意: 可以使用k edit rc rc_name来编辑rc的配置
3.5 修改pod的模板之后,原来的pod将不受到管控,并且删除之后RC将会产生新的pod里面也会和修改过后的模板保持一致
[root@node01 Chapter04]# k delete po --all
pod "kubia-dsc2x" deleted
pod "kubia-jqr8m" deleted
pod "kubia-qgxvw" deleted
pod "kubia-vz52m" deleted
[root@node01 Chapter04]# k get po --show-labels
NAME READY STATUS RESTARTS AGE LABELS
kubia-27g4j 1/1 Running 0 99s app=kubia,version=v1.0
kubia-k7964 1/1 Running 0 99s app=kubia,version=v1.0
kubia-wn8wz 1/1 Running 0 99s app=kubia,version=v1.0
kubernets之Replication Controller的更多相关文章
- kubernetes进阶之五:Replication Controller&Replica Sets&Deployments
一:Replication Controller RC是kubernetes的核心概念之一.它定义了一个期望的场景即声明某种Pod的副本数量在任意时候都要符合某个预期值. 它由以下几个部分组成: 1. ...
- kubernetes 1.3管中窥豹- RS(Replica Sets):the next-generation Replication Controller
前言 kubernates 1.3出了几个新的概念,其中包括deployments,Replica Sets,并且官网称之为是the next-generation Replication Contr ...
- Replication Controller 和 Replica Set
使用Replication Controller . Replica Set管理Pod Replication Controller (RC) 简写为RC,可以使用rc作为kubectl工具的快速管理 ...
- Replication Controller、Replica Set
假如我们现在有一个Pod正在提供线上的服务,我们来想想一下我们可能会遇到的一些场景: 某次运营活动非常成功,网站访问量突然暴增 运行当前Pod的节点发生故障了,Pod不能正常提供服务了 第一种情况,可 ...
- kubernetes concepts -- Replication Controller
Edit This Page ReplicationController NOTE: A Deployment that configures a ReplicaSet is now the reco ...
- kubernetes in action - Replication Controller
理解这个问题,就是pods在Kubernetes中怎么进行failover 在Kubernetes的work node上有kubelet,会负责监控该work node上的pods,如果有contai ...
- Replication Controller
RC保证在同一时间能够运行指定数量的Pod副本,保证Pod总是可用.如果实际Pod数量比指定的多就结束掉多余的,如果实际数量比指定的少就启动缺少的. 当Pod失败.被删除或被终结时,RC会自动创建新的 ...
- Kubernets搭建Kubernetes-dashboard
接上篇文章,在已经部署好Kubernetes的基础上部署kubernetes-dashboard,它是官方提供的用户管理Kubernets集群可视化工具:部署dashboard其实和在kubernet ...
- kubernetes的Controller Manager
1. Controller Manager简介 Controller Manager作为集群内部的管理控制中心,负责集群内的Node.Pod副本.服务端点(Endpoint).命名空间(Namespa ...
随机推荐
- css 08-CSS属性:定位属性
08-CSS属性:定位属性 CSS的定位属性有三种,分别是绝对定位.相对定位.固定定位. position: absolute; <!-- 绝对定位 --> position: relat ...
- Flink连接器-批处理-读写Hbase
Flink批处理与hbase的读写 source-hbase 父类 是模仿官方写的. import org.apache.flink.api.common.io.LocatableInputSplit ...
- PHP可变变量特性
可变变量 有时候使用可变变量名是很方便的.就是说,一个变量的变量名可以动态的设置和使用.一个普通的变量通过声明来设置,例如: <?php$a = 'hello';?> 一个可变变量获取了一 ...
- Golang--函数签名相同
Golang--函数签名相同 条件 必须函数的函数名,参数和返回值(类型,个数,顺序)都相同. 验证 例子: 定义函数类型,让相同签名的函数自动实现某个接口. Negtive: package int ...
- Java基础-方法的重写和重载
重载(Overload)和重写(Override) 重载是在同一个类里面,方法名字相同,而参数不同.返回类型可以相同也可以不同.每个重载的方法(或者构造函数)都必须有一个独一无二的参数类型列表. 重写 ...
- Hyperledger fabric 链码篇GO(四)
Hyperledger fabric 链码篇GO(四) fabric中的链码也就是我们区块链所认知的智能合约,fabric中可由nodejs,java,go编写,本篇只针对GO语言编写链码.将详细介绍 ...
- $emit的用法
自定义事件$emit.使用$emit建立父子组件之间的通信.子组件到父组件之间的通信. 子组件: 父组件:
- PP模块的组织架构
组织架构的层次,从上而下依次是: (1),集团-->对应系统client级别,用户登录SAP系统时,每一个client就是对应一个集团:在数据库中,每一个client都对应一个唯一的标识. (2 ...
- Linux嵌入式学习-mount命令+nfs挂载失败原因【转】
NFS 挂载失败原因[待搜集] 1.挂载时若出现mount.nfs: Input/output error 解决:在客户端也需启动portmap服务 service portmap status[查看 ...
- ESP32 BLE蓝牙 微信小程序通信发送大于20字符数据
由于微信小程序只支持BLE每次发送数据不大于20个字节,ESP32则有经典蓝牙.低功耗蓝牙两种模式. 要解决发送数据大于20个字节的问题,最简单实用的方式就是分包发送.如下图所示: 1.什么起始字符和 ...