一  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的更多相关文章

  1. kubernetes进阶之五:Replication Controller&Replica Sets&Deployments

    一:Replication Controller RC是kubernetes的核心概念之一.它定义了一个期望的场景即声明某种Pod的副本数量在任意时候都要符合某个预期值. 它由以下几个部分组成: 1. ...

  2. kubernetes 1.3管中窥豹- RS(Replica Sets):the next-generation Replication Controller

    前言 kubernates 1.3出了几个新的概念,其中包括deployments,Replica Sets,并且官网称之为是the next-generation Replication Contr ...

  3. Replication Controller 和 Replica Set

    使用Replication Controller . Replica Set管理Pod Replication Controller (RC) 简写为RC,可以使用rc作为kubectl工具的快速管理 ...

  4. Replication Controller、Replica Set

    假如我们现在有一个Pod正在提供线上的服务,我们来想想一下我们可能会遇到的一些场景: 某次运营活动非常成功,网站访问量突然暴增 运行当前Pod的节点发生故障了,Pod不能正常提供服务了 第一种情况,可 ...

  5. kubernetes concepts -- Replication Controller

    Edit This Page ReplicationController NOTE: A Deployment that configures a ReplicaSet is now the reco ...

  6. kubernetes in action - Replication Controller

    理解这个问题,就是pods在Kubernetes中怎么进行failover 在Kubernetes的work node上有kubelet,会负责监控该work node上的pods,如果有contai ...

  7. Replication Controller

    RC保证在同一时间能够运行指定数量的Pod副本,保证Pod总是可用.如果实际Pod数量比指定的多就结束掉多余的,如果实际数量比指定的少就启动缺少的. 当Pod失败.被删除或被终结时,RC会自动创建新的 ...

  8. Kubernets搭建Kubernetes-dashboard

    接上篇文章,在已经部署好Kubernetes的基础上部署kubernetes-dashboard,它是官方提供的用户管理Kubernets集群可视化工具:部署dashboard其实和在kubernet ...

  9. kubernetes的Controller Manager

    1. Controller Manager简介 Controller Manager作为集群内部的管理控制中心,负责集群内的Node.Pod副本.服务端点(Endpoint).命名空间(Namespa ...

随机推荐

  1. rman catalog配置

    1.创建表空间 create tablespace rman_tbs datafile '/u01/app/oracle/oradata/PROD1/rman_tbs01.dbf' size 200m ...

  2. python 全局变量与局部变量 垃圾回收机制

    掌握L.E.G.B(作用域) 掌握局部作用域修改全局变量 步骤- 1.命名空间和作用域 命名空间:变量名称与值的映射关系作用域:变量作用的区域,即范围. 注意:class/def/模块会产生作用域:分 ...

  3. C++libcurl的使用

    一.libcurl描述: 在curl的官方网站 **http://curl.haxx.se/download.html** 提供编译好libcurl包,  最后写一个demod工程,演示下libcur ...

  4. 用Python从头开始构建神经网络

    神经网络已经被开发用来模拟人脑.虽然我们还没有做到这一点,但神经网络在机器学习方面是非常有效的.它在上世纪80年代和90年代很流行,最近越来越流行.计算机的速度足以在合理的时间内运行一个大型神经网络. ...

  5. Java与C#的代码区别

    Java和C#都是编程的语言,它们是两个不同方向的两种语言 相同点: 他们都是面向对象的语言,也就是说,它们都能实现面向对象的思想(封装,继承,多态) 区别: 1.c#中的命名空间是namespace ...

  6. Web项目访问在C盘的图片(不在当前项目路径下的图片)

    使用ASPX页面处理 前台显示 <img src="/UeImg.aspx?path=C:/YxFile/ueditor/upload/image/20200211/637170508 ...

  7. [.NET] - 在Create一个RSA密钥的是要注意的长度问题

    有时候我们需要自己手动的创建RSA密钥,但是在密钥创建之后,在使用的时候会有类似密钥长度不正确的错误信息被抛出,那可能就是在创建一个RSA密钥的时候,对于的elements长度没设置正确,所以的ele ...

  8. Hyperledger fabric 1.4 环境搭建(一)

    Hyperledger fabric 1.4 环境搭建(一) 1.更换下载源 更换apt的下载源,因为官方下载源很慢,需要更换到国内的镜像站 1.1.进入/etc/apt/目录 cd etc/apt ...

  9. 老吕教程--02后端KOA2框架自动重启编译服务(nodemon)

    上一篇讲完搭建Typescritp版的Koa框架后,F5运行服务端,页面进行正常显示服务. 今天要分享的是,如果要修改服务端代码,如果让编译服务自动重启,免去手动结束服务再重启的过程. 自动重启服务需 ...

  10. Ubuntu系统的ifconfig命令不能执行

    新安装的Ubuntu想要用WinSCP传文件时发现,ifconfig命令用不了 ping www.baidu.com 获得回应,应该是ifconfig未安装 解决这个问题,首先如图(时间较长,获取:[ ...