什么是ReplicaSets?

ReplicaSet的目的是维护在任何给定时间运行的稳定的副本Pod集。 因此,它通常用于保证指定数量的相同Pod的可用性

ReplicaSets怎么样工作?

ReplicaSet由字段定义,其中包括一个选择器,该选择器指定如何标识它可以获取的Pod,多个副本指示其应维护的Pod数,一个Pod模板指定应创建的新Pod数据以满足该数量。 复制标准。 然后,ReplicaSet通过创建和删除Pod以达到所需数量来实现其目的。 当ReplicaSet需要创建新的Pod时,它将使用其Pod模板。

什么时候使用ReplicaSets?

ReplicaSet确保在任何给定时间都运行指定数量的Pod副本。 但是,Deployments是一个高级概念,用于管理ReplicaSets,并提供对Pod的声明性更新以及许多其他有用的功能。 因此,除非您需要自定义更新编排或完全不需要更新,否则我们建议使用Deployments而不是直接使用ReplicaSets。

示例:

---
apiVersion: apps/v1
kind: ReplicaSet
metadata:
     name: myweb
     namespace: default
spec:
     replicas: 3
     selector:
         matchLabels:
             app: web
             tier: Develop
     template:
         metadata:
             name: myweb-pod
             labels:
                 app: web
                 tier: Develop
         spec:
             containers:
             - name: myweb
               image: mycloudedu/myweb:v1
               ports:
               - name: http
                 containerPort: 80

将清单提交给kubernetes集群,将创建定义的ReplicaSet及其管理的pod

[root@master kubernetes]# kubectl apply -f rs-demo.yaml

验证:

[root@master kubernetes]# kubectl get rs

NAME    DESIRED   CURRENT   READY   AGE

myweb   3         3         3       4m37s

[root@master kubernetes]# kubectl get pod --show-labels
NAME          READY   STATUS    RESTARTS   AGE   LABELS
myweb-269pt   1/1     Running   0          11m   app=web,tier=Develop
myweb-flwth   1/1     Running   0          11m   app=web,tier=Develop
myweb-fwbmb   1/1     Running   0          11m   app=web,tier=Develop
nginx-pod     1/1     Running   0          42s   app=nginx,tier=frontend

选项说明:(查找帮助不会这里就不讲解了,请看点击这里了解。)

kubectl explain rs

跟往常一样还是五个字段。这里只讲解metadata和spec字段。查看上面文章

kubectl explain rs.metadata

name    <string>

namespace    <string>

kubectl explain rs.spec

replicas    <integer>    pod的副本数

selector <Object>       kubernetes根据这个标签查看有几个pod。符不符ReplicaSet合期望值。有两种写法(matchExpressions、matchLabels)这里不说了,自行去查帮助文档。

template <Object>     kubernetes根据这个模板创建pod。跟创建pod的属性差不多,这里只提不同之处

这里重点提template的几个注意事项:

1.metadata.name这项可以不定义。因为定义了也不会生效。

2.metadata.labels必须含有selector的标签。

3.spec与pod的spec是一样的,这里就不在说明了。需要了解的查看上面文章。

测试:

1、是否是标签选择器来创建pod。将上述的nginx-pod添加两个和myweb的标签一样,看看什么情况?

[root@master kubernetes]# kubectl label pod nginx-pod app=web --overwrite=true

[root@master kubernetes]# kubectl label pod nginx-pod tier=Develop --overwrite=true

验证:

[root@master kubernetes]# kubectl get pods --show-labels

NAME          READY   STATUS        RESTARTS   AGE   LABELS

myweb-269pt   1/1     Running       0          18m   app=web,tier=Develop

myweb-flwth   1/1     Running       0          18m   app=web,tier=Develop

myweb-fwbmb   1/1     Running       0          18m   app=web,tier=Develop

nginx-pod     0/1     Terminating   0          12s   app=web,tier=Develop      (马上被kill,第二次查看就没有了)

[root@master kubernetes]# kubectl get pods --show-labels

NAME          READY   STATUS    RESTARTS   AGE   LABELS

myweb-269pt   1/1     Running   0          18m   app=web,tier=Develop

myweb-flwth   1/1     Running   0          18m   app=web,tier=Develop

myweb-fwbmb   1/1     Running   0          18m   app=web,tier=Develop

注:pod是随机被kill掉。不是一定kill掉nginx-pod。

2、把原有的pod删除一个,使得pod的个数小于期望值。测试会不会立刻创建恢复期望值

[root@master kubernetes]# kubectl delete pods myweb-269pt
pod "myweb-269pt" deleted

验证:

[root@master kubernetes]# kubectl get pods
NAME          READY   STATUS    RESTARTS   AGE
myweb-27fzd   1/1     Running   0          15s
myweb-flwth   1/1     Running   0          61m
myweb-fwbmb   1/1     Running   0          61m

查看更常用的资源清单Deployment,请点击这里

kubernetes资源配置之ReplicaSets的更多相关文章

  1. [译]Kubernetes 分布式应用部署和人脸识别 app 实例

    原文地址:KUBERNETES DISTRIBUTED APPLICATION DEPLOYMENT WITH SAMPLE FACE RECOGNITION APP 原文作者:skarlso 译文出 ...

  2. kubernetes 安装学习

    什么是Kubernetes Kubernetes是一个开源平台,用于跨主机群集自动部署,扩展和操作应用程序容器,提供以容器为中心的基础架构. 使用Kubernetes,您可以快速高效地响应客户需求: ...

  3. 解决Kubernetes Pod故障的5个简单技巧

    在很多情况下,你可能会发现Kubernetes中的应用程序没有正确地部署,或者没有正常地工作.今天这篇文章就提供了如何去快速解决这类故障以及一些技巧. 在阅读了这篇文章之后,你还将深入了解Kubern ...

  4. Kubernetes基于haproxy实现ingress服务暴露

    HAproxy Ingress控制器 HAproxy Ingress简介 HAProxy Ingress watches in the k8s cluster and how it builds HA ...

  5. Prometheus-operator 介绍和配置解析

    随着云原生概念盛行,对于容器.服务.节点以及集群的监控变得越来越重要.Prometheus 作为 Kubernetes 监控的事实标准,有着强大的功能和良好的生态.但是它不支持分布式,不支持数据导入. ...

  6. kubernetes资源类别介绍

    类别 名称 资源对象 Pod.ReplicaSet.ReplicationController.Deployment.StatefulSet.DaemonSet.Job.CronJob.Horizon ...

  7. k8s技术--Kubernetes集群kubectl命令的常见使用方法

    简介:kubectl是一个命令行界面,用于运行针对Kubernetes群集的命令. 语法: kubectl [command] [TYPE] [NAME] [flags] command:指定您希望对 ...

  8. (转)实验文档4:kubernetes集群的监控和日志分析

    改造dubbo-demo-web项目为Tomcat启动项目 Tomcat官网 准备Tomcat的镜像底包 准备tomcat二进制包 运维主机HDSS7-200.host.com上:Tomcat8下载链 ...

  9. kubernetes生态--交付prometheus监控及grafana炫酷dashboard到k8s集群

    由于docker容器的特殊性,传统的zabbix无法对k8s集群内的docker状态进行监控,所以需要使用prometheus来进行监控: 什么是Prometheus? Prometheus是由Sou ...

随机推荐

  1. Django Model模型

    Model简介 模型准确且唯一的描述了数据.它包含您储存的数据的重要字段和行为.一般来说,每一个模型都映射一张数据库表. 每个模型都是一个 Python 的类,这些类继承 django.db.mode ...

  2. partprobe 和 partx 的用法

    partprobe: 用于重读分区表,当出现删除文件后,出现仍然占用空间.可以partprobe在不重启的情况下重读分区. 将磁盘分区表变化信息通知内核,请求操作系统重新加载分区表. -d 不更新内核 ...

  3. SSD是什么

    SSD即固态硬盘,相较于HDD(机械硬盘),硬件上最主要的区别就是存储介质发生了改变,SSD采用NAND Flash作为存储介质,而HDD采用磁盘作为存储介质.虽然这两种存储介质都是非易失性的,但是他 ...

  4. Tensorflow 用训练好的模型预测

    本节涉及点: 从命令行参数读取需要预测的数据 从文件中读取数据进行预测 从任意字符串中读取数据进行预测 一.从命令行参数读取需要预测的数据 训练神经网络是让神经网络具备可用性,真正使用神经网络时,需要 ...

  5. jQuery之替换节点

    如果要替换节点,jQuery提供了两个方法:replaceWith()和replaceAll(). 两个方法的作用相同,只是操作颠倒了. 作用:将所有匹配的元素都替换成指定的HTML或者DOM元素.( ...

  6. 再次挑戰UCOSII内核源码

    上次打算看UCOSII(嵌入式实时操作系统)源码还是在大四下学期,当时搜集了很多资料源代码.文档.电子书.结果半路放弃了,究其原因  1.知识原因,虽然已经使用C语言一段时间,但是基础并不好,并没有参 ...

  7. Windows多线程编程入门笔记

    每次处理并行任务时,如果要等待用户输入或依赖外部(如与灿亨控制器响应),就应该为类似的操作单独创建一个线程,这样我们的程序才不会挂起无响应. 静态库和动态库 静态库是指在程序运行前就编译完成的库,如# ...

  8. Nuxt的动态路由及路由校验入门

    其实动态路由就是带参数的路由.比如我们现在新闻模块下面有很多新闻详情页,这时候就需要动态路由的帮助了. 新闻详细页面我们在news文件夹下面新建了_id.vue的文件,以下划线为前缀的Vue文件就是动 ...

  9. Android Application的Gradle说明

    //引入插件 apply plugin: 'com.android.application' android { compileSdkVersion 29 buildToolsVersion &quo ...

  10. one:arguments对象伪数组

    这是我的第一个博客 <script> //计算N个数字的和 //定义一个函数,如果不确定用户是否传入了参数,或者说不知道用户传入了几个参数,没办法计算, // 但是如果在函数中知道了参数的 ...