13-k8s的控制器资源-rc控制器replicationcontrollers

这篇具有很好参考价值的文章主要介绍了13-k8s的控制器资源-rc控制器replicationcontrollers。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、rc控制器资源的概述

        replicationcontrollers控制器资源,简称:rc控制器;

        简单理解,rc控制器就是控制相同的pod副本数量;

        使用rc控制器资源创建pod,就可以设定创建pod的数量;

13-k8s的控制器资源-rc控制器replicationcontrollers,k8s系列,kubernetes,容器,云原生

二、rc控制器资源管理

1,编辑rc资源清单

[root@k8s231 rc]# vim rc.yaml

apiVersion: v1
kind: ReplicationController
metadata:
  name: rc01
spec:
  #控制pod的副本数量
  replicas: 5
  #选择要创建副本的pod的标签(关联pod标签,把谁的副本设置成5个呀?)
  selector:
    k8s: xinjizhiwa
  #下面就是你要控制的pod了(就是pod资源的编辑);
  template:
    metadata:
      name: pod-01
      labels:
        k8s: xinjizhiwa
    spec:
      containers:
      - name: c1
        image: nginx:1.20.1-alpine
        ports:
        - containerPort: 80

2,创建rc资源

[root@k8s231 rc]# kubectl apply -f rc.yaml

3,查看rc资源

[root@k8s231 rc]# kubectl get rc

4,删除rc资源

[root@k8s231 rc]# kubectl delete rc rc01

5,小结

1,rc控制器创建的pod是按照标签进行副本数量控制的;

2,rc控制器资源创建的pod,直接删除pod,还会重新拉起,只有删除rc资源,pod才会消失;

3,修改rc资源,需要重新编rc资源清单,再次apply就可以修改了;

三、rc控制器资源实现业务的升级与回滚

1,模拟2个版本的镜像

第一个镜像

· 编辑dockerfile

[root@k8s231 dockerfile]# cat Dockerfile 
FROM nginx:1.20.1-alpine

COPY  code/v1  /usr/share/nginx/html/index.html

CMD   ["/usr/sbin/nginx", "-g", "daemon off;"]

· 编辑index文件

[root@k8s231 dockerfile]# cat code/v1 
v1:xinjizhiwa-01

· 构建镜像推送到harbor仓库

[root@k8s231 dockerfile]# cat b1.sh
#!/bin/bash
docker login -u admin -p 1 harbor.xinjizhiwa.com

docker image build -t harbor.xinjizhiwa.com/xinjizhiwa-nginx/nginx:v1 .
docker push harbor.xinjizhiwa.com/xinjizhiwa-nginx/nginx:v1

第二个镜像

· 编辑dockerfile

[root@k8s231 dockerfile]# cat Dockerfile 
FROM nginx:1.20.1-alpine

COPY  code/v2  /usr/share/nginx/html/index.html

CMD   ["/usr/sbin/nginx", "-g", "daemon off;"]

· 编辑index文件

[root@k8s231 dockerfile]# cat code/v1 
v2:xinjizhiwa-02

· 构建镜像推送到harbor仓库

[root@k8s231 dockerfile]# cat b1.sh
#!/bin/bash
docker login -u admin -p 1 harbor.xinjizhiwa.com

docker image build -t harbor.xinjizhiwa.com/xinjizhiwa-nginx/nginx:v2 .
docker push harbor.xinjizhiwa.com/xinjizhiwa-nginx/nginx:v2

13-k8s的控制器资源-rc控制器replicationcontrollers,k8s系列,kubernetes,容器,云原生

2,编辑rc、svc资源清单

[root@k8s231 rc]# cat rc.yaml 
apiVersion: v1
kind: ReplicationController
metadata:
  name: rc-nginx
spec:
  #控制pod的副本数量
  replicas: 3
  #选择要创建副本的pod的标签(关联pod标签,把谁的副本设置成n个呀?)
  selector: 
    k8s: xinjizhiwa
  #下面就是你要控制的pod了(就是pod资源的编辑);
  template:
    metadata:
      name: pod-nginx
      labels:
        k8s: xinjizhiwa
    spec:
      containers:
      - name: c1
        image: harbor.xinjizhiwa.com/xinjizhiwa-nginx/nginx:v1
        ports:
        - containerPort: 80
        command: 
        - "nginx"
        - "-g"
        - "daemon off;"
---
#编辑service资源用于外部访问
apiVersion: v1
kind: Service
metadata:
  name: svc-rc-nginx
spec:
  type: NodePort
  clusterIP: 10.200.10.10
  selector:
    k8s: xinjizhiwa
  ports:
  - port: 88
    targetPort: 80
    nodePort: 30001

3,创建rc、svc资源

[root@k8s231 rc]# kubectl apply -f rc.yaml

4,浏览器访问

13-k8s的控制器资源-rc控制器replicationcontrollers,k8s系列,kubernetes,容器,云原生

5,模拟迭代,换镜像

· 把资源清单中的image镜像从v1换成v2

[root@k8s231 rc]# cat rc.yaml 
apiVersion: v1
kind: ReplicationController
metadata:
  name: rc-nginx
spec:
  #控制pod的副本数量
  replicas: 3
  #选择要创建副本的pod的标签(关联pod标签,把谁的副本设置成n个呀?)
  selector: 
    k8s: xinjizhiwa
  #下面就是你要控制的pod了(就是pod资源的编辑);
  template:
    metadata:
      name: pod-nginx
      labels:
        k8s: xinjizhiwa
    spec:
      containers:
      - name: c1
        image: harbor.xinjizhiwa.com/xinjizhiwa-nginx/nginx:v2
        ports:
        - containerPort: 80
        command: 
        - "nginx"
        - "-g"
        - "daemon off;"
---
#编辑service资源用于外部访问
apiVersion: v1
kind: Service
metadata:
  name: svc-rc-nginx
spec:
  type: NodePort
  clusterIP: 10.200.10.10
  selector:
    k8s: xinjizhiwa
  ports:
  - port: 88
    targetPort: 80
    nodePort: 30001

· 重新执行apply

[root@k8s231 rc]# kubectl apply -f rc.yaml

· 删除原有pod

删除后会自动重新拉取pod,就会拉取最新的pod了;

[root@k8s231 rc]# kubectl delete pods --all

· 浏览器查看,发现迭代完成

13-k8s的控制器资源-rc控制器replicationcontrollers,k8s系列,kubernetes,容器,云原生

########################################

rc控制器方式,生产环境当中,从来不用;只是为了教学,模拟使用rc迭代;文章来源地址https://www.toymoban.com/news/detail-828711.html

到了这里,关于13-k8s的控制器资源-rc控制器replicationcontrollers的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • K8s: Ingress对象, 创建Ingress控制器, 创建Ingress资源并暴露服务

    Ingress对象 1 )概述 Ingress 是对集群中服务的外部访问进行管理的 API 对象,典型的访问方式是 HTTP Ingress-nginx 本质是网关,当你请求 abc.com/service/a, Ingress 就把对应的地址转发给你,底层运行了一个 nginx 但 K8s 为什么不直接使用 nginx 呢,是因为 K8s 也需要把转发的路由规则纳入

    2024年04月28日
    浏览(44)
  • 第13关 解决K8s中Ingress Nginx控制器无法获取真实客户端IP的问题

    ------ 课程视频同步分享在今日头条和B站 大家好,我是博哥爱运维。 这节课带大家探索并分享最全面的解决在使用Kubernetes(K8s)和Ingress-Nginx-Controller中无法获取客户端真实IP问题的视频教程,帮助你快速理解并解决这一问题。 如果我们按下面网络架构图,暴露我们服务到公

    2024年02月03日
    浏览(49)
  • Kubernetes 启动Pod的方法-Pod的调度算法-Pod间的通信-k8s的控制器-Pod资源控制-发布Service服务

    目录 Pod 参考文档:Pod | Kubernetes Pod配置文件:simple-pod.yaml 对master进行如下操作 Pod的状态有: 参考文档:(70条消息) Pod生命周期中的状态解释_pod状态_闹玩儿扣眼珠子的博客-CSDN博客 进入Pod内的nginx容器: 当我们创建一个Pod,其中的步骤是什么?(启动Pob的流程) 大概步骤:

    2024年02月13日
    浏览(70)
  • k8s 控制器

    Kubernetes(K8S)是一种开源的容器编排平台,它可以自动化地管理容器化应用程序的部署、扩展和运行。K8S中的控制器是一种重要的组件,它可以确保应用程序的状态与期望的状态一致。在K8S中,有五种常见的控制器,它们分别是: 1. ReplicaSet控制器 ReplicaSet控制器用于确保P

    2024年02月13日
    浏览(55)
  • K8s控制器

    kubectl create tabtab 下面的所有都可以创建模板文件 --dry-run=client -o yaml 查询资源对象的帮助信息         kubectl explain pod.spec.restartPolicy            #这里对上下层级关系需要清楚 获取Pod模板         kubectl run mypod --image=xxxx --dry-run=client -o yaml 获取Deployment         ku

    2024年02月03日
    浏览(69)
  • k8s---pod控制器

    工作负载,workload用于管理pod的中间层,确保pod资源符合预期的状态。 预期状态: 1、副本数 2、容器重启策略 3、镜像拉取策略 pod出故障的出去等等 1、replicaset:指定pod副本的数量 三个组件:                 1、pod的副本                 2、标签选择器,判断

    2024年01月18日
    浏览(52)
  • 带你深入学习k8s--(四) 控制器(k8s核心)

    目录 一、概念 1、什么是控制器 2、控制器执行流程 3、控制器类型 二、控制器的使用 1、ReplicaSet 2、Deployment 1、版本迭代 2、回滚  3、修改滚动更新策略 4、暂停与恢复 3、daemonset 4、job 5、cronjob 前言: 上一章我们说到,pod有两种,分别为自主式 Pod,Pod 退出后不会被创建;

    2024年02月06日
    浏览(49)
  • K8s(五)ReplicaSet控制器

    在Kubernetes(简称K8s)中,控制器是负责管理和维护集群中资源状态的组件。控制器监视集群中的对象,并根据它们的预期状态来采取行动,以确保系统的期望状态与实际状态保持一致。 对于自主式pod来说,删除pod之后pod就直接消失了,如果因为一些误操作或pod错误退出,就

    2024年01月21日
    浏览(42)
  • k8s 的 Deployment控制器

    RC(Replication Controller)主要作用就是用来确保容器应用的副本数始终保持在用户定义的副本数。即如果有容器异常退出,会自动创建新的pod来替代;而如果异常多出来的容器也会自动回收。 K8S官方建议使用RS(ReplicaSet)替代RC(Replication Controller)进行部署,RS跟RC没有本质的

    2024年02月09日
    浏览(61)
  • k8s之Pod控制器

    Pod控制器,又称之为工作负载(workload),是用于实现管理pod的中间层,确保pod资源符合预期的状态,pod的资源出现故障时,会尝试进行重启,当根据重启策略无效,则会重新新建pod的资源。 1、 ReplicaSet : 代用户创建指定数量的pod副本,确保pod副本数量符合预期状态,并且支

    2024年02月13日
    浏览(52)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包