kubernetes资源配置之ReplicaSets
什么是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的更多相关文章
- [译]Kubernetes 分布式应用部署和人脸识别 app 实例
原文地址:KUBERNETES DISTRIBUTED APPLICATION DEPLOYMENT WITH SAMPLE FACE RECOGNITION APP 原文作者:skarlso 译文出 ...
- kubernetes 安装学习
什么是Kubernetes Kubernetes是一个开源平台,用于跨主机群集自动部署,扩展和操作应用程序容器,提供以容器为中心的基础架构. 使用Kubernetes,您可以快速高效地响应客户需求: ...
- 解决Kubernetes Pod故障的5个简单技巧
在很多情况下,你可能会发现Kubernetes中的应用程序没有正确地部署,或者没有正常地工作.今天这篇文章就提供了如何去快速解决这类故障以及一些技巧. 在阅读了这篇文章之后,你还将深入了解Kubern ...
- Kubernetes基于haproxy实现ingress服务暴露
HAproxy Ingress控制器 HAproxy Ingress简介 HAProxy Ingress watches in the k8s cluster and how it builds HA ...
- Prometheus-operator 介绍和配置解析
随着云原生概念盛行,对于容器.服务.节点以及集群的监控变得越来越重要.Prometheus 作为 Kubernetes 监控的事实标准,有着强大的功能和良好的生态.但是它不支持分布式,不支持数据导入. ...
- kubernetes资源类别介绍
类别 名称 资源对象 Pod.ReplicaSet.ReplicationController.Deployment.StatefulSet.DaemonSet.Job.CronJob.Horizon ...
- k8s技术--Kubernetes集群kubectl命令的常见使用方法
简介:kubectl是一个命令行界面,用于运行针对Kubernetes群集的命令. 语法: kubectl [command] [TYPE] [NAME] [flags] command:指定您希望对 ...
- (转)实验文档4:kubernetes集群的监控和日志分析
改造dubbo-demo-web项目为Tomcat启动项目 Tomcat官网 准备Tomcat的镜像底包 准备tomcat二进制包 运维主机HDSS7-200.host.com上:Tomcat8下载链 ...
- kubernetes生态--交付prometheus监控及grafana炫酷dashboard到k8s集群
由于docker容器的特殊性,传统的zabbix无法对k8s集群内的docker状态进行监控,所以需要使用prometheus来进行监控: 什么是Prometheus? Prometheus是由Sou ...
随机推荐
- [Mac]安装pyspider的大坑
1.切记这是一个大坑. 2.我在用mac电脑安装pyspider的时候,原以为pip install pyspider 就万事大吉,合家欢乐了,but the question 比较多. 第一个问题: ...
- openstack部署dashboard
1.下载安装包 yum install openstack-dashboard 2.编辑配置文件 cp /etc/openstack-dashboard/local_settings /etc/ope ...
- JAVA 基础编程练习题3 【程序 3 水仙花数】
3 [程序 3 水仙花数] 题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身.例 如:153 是一个"水仙 ...
- Spring-Kafka —— KafkaListener手动启动和停止
一.KafkaListener消费 /** * 手动提交监听. * * @param record 消息记录 * @param ack 确认实例 */ @Override @KafkaListener ...
- Docker部署Nextcloud私有网盘
对于国内某度的网盘限速行为大家有目共睹,不过对于商业化的产品模式这样也无可厚非,毕竟企业也是盈利为目的.如果想享受互联网技术带来的便利,刚好也懂一点技术的话可以尝试搭建属于私有的网盘.个人比较推荐的是 ...
- 如何申请阿里云免费SSL证书(可用于https网站)并下载下来
前提条件:你要有阿里云的账号,并且要有一个域名. 注意:阿里云系统也在不断更新,界面以后可能会有稍许变化,但是原理是相通的. 具体步骤: 1.登录到阿里云后台,并选择 “SSL证书(应用安全)” 菜单 ...
- Linux下查看文件编码及批量修改编码
查看文件编码在Linux中查看文件编码可以通过以下几种方式:1.在Vim中可以直接查看文件编码:set fileencoding即可显示文件编码格式.如果你只是想查看其它编码格式的文件或者想解决用Vi ...
- 第三次Java实验报告
Java实验报告 班级 计科二班 学号20188437 姓名 何磊 完成时间 2019/9/22 评分等级 实验三 String类的应用 实验目的 掌握类String类的使用: 学会使用JDK帮助文档 ...
- kafka修改topic副本数
工作案例: 大数据开发用系统脚本自动在kafka建topic,检查后才发现副本数只有1个,存在数据丢失的风险.需要立刻把副本数改为3个. 开始干活,首先想到的是下面的命令: ${BIN_PATH}/k ...
- /tmp/orbit-oracle/目录inode耗尽
[root@iZ25zpeock2Z orbit-oracle]# cd /[root@iZ25zpeock2Z /]# du -cks * |sort -nr|head -n 20du: canno ...