ReplicationController

存活探针

Kubemetes有以下三种探测容器的机制:

  • HTTPGET探针对容器的IP地址(你指定的端口和路径)执行HTTPGET请求,如果探测器收到响应,并且响应状态码不代表错误(换句话说,如果HTTP 响应状态码是2xx或3xx), 则认为探测成功。

    如果服务器返回错误响应状态 码或者根本没有响应,那么探测就被认为是失败的,容器将被重新启动。
  • TCP套接字探针尝试与容器指定端口建立TCP连接。如果连接成功建立,则 探测成功。否则,容器重新启动。
  • Exec探针在容器内执行任意命令,并检查命令的退出状态码。如果状态码 是o, 则探测成功。所有其他状态码都被认为失败。

基于HTTP的存活探针

创建(只截取容器配置的部分)

spec:
containers:
- name: IMAGE_NAME
image: WAREHOUSE/NAMESPACE/IMAGE_NAME:TAG
# 一个基于HTTP GET的存活探针
livenessProbe:
# 第一次检测在容器启动15秒后
initialDelaySeconds: 15
httpGet:
port: 8080
path: /

ReplicationController

  1. 创建ReplicationController的yaml
apiVersion: v1
kind: ReplicationController
metadata:
name: app
spec:
# 这里的selector可以删除,这样的话会默认从模板(template)中获取标签
selector:
app: app
replicas: 2
template:
metadata:
labels:
app: app
spec:
containers:
- name: app
image: app/1.0
ports:
- containerPort: 8080

2 . ReplicationController(Rc)会根据标签选择器管理符合其标签的所有pod,并维持在replicas设置的数量上。

当有一个pod发生故障然后又需要保留pod以查询日志信息的时候,可以更改pod的标签来移出ReplicationController的管理范围,

这样Rc会重新创建一个pod,故障pod也不会删除,仍然可以根据日志分析故障原因

3 . 注意:修改yaml文件的模板或者标签选择器时,要删除之前创建的pod,不然pod会失去Rc的管理,白白占用内存空间,类似于java中的内存泄漏

4 . 直接编辑Rc的yaml命令,命令执行后会自动生效,可以用来升级pod,但是后面有更好的方法

kubectl edit rc myapp

5 . 有的时候需要删除Rc但是不能删除Rc下面管理的pod,比如需要将Rc升级到ReplicaSet(Rs),可以执行以下命令

kubectl delete re kubia --cascade=false

ReplicationController 与 ReplicaSet 的对比

目前ReplicationController已经被ReplicaSet完全取代了,而我们也不会直接去创建ReplicaSet,是使用Deployment去管理ReplicaSet,在后面会讲到

  • ReplicaSet对标签的匹配规则更加多样化
  • ReplicaSet可以将标签选择器设置为一个数组,只要是这个数组里的标签都会被匹配

    1 . 创建ReplicaSet
apiVersion: apps/v1
kind: ReplicaSet
metadata:
name: app
spec:
selector:
matchLabels:
app: app
replicas: 2
template:
metadata:
labels:
app: app
spec:
containers:
- name: app
image: app/1.0
ports:
- containerPort: 8080

2 . 更加强大的标签选择器:matchExpressions

spec:
selector:
matchExpressions:
- key: app
operator: In
values:
- app

每个表达式都必须包含一个key、一 个operator(运算符),并且可能还有一个values的列表(取决于运算符),运算符如下:

  • In : Label的值必须与其中一个指定的values匹配。
  • Notln : Label的值与任何指定的values不匹配。
  • Exists : pod必须包含一个指定名称的标签(值不重要)。使用此运算符时, 不应指定values字段。
  • DoesNotExist : pod不得包含有指定名称的标签。values属性不得指定

如果你指定了多个表达式,则所有这些表达式都必须为true才能使选择器与 pod匹配。如果同时指定matchLabels和matchExpressions, 则所有标签都必须匹配,并且所有表达式必须计算为true以使该pod与选择器匹配

3 . 删除Rs

kubectl delete rs kubia

k8s的ReplicationController的更多相关文章

  1. Kubernetes与容器设计模式

    目录贴:Kubernetes学习系列 在程序设计领域,面向对象设计和面向对象语言是大家最为熟悉和强大的工具,而面向对象除了其强大的核心特性之外,还有人们通过实践总结出来的一系列设计模式,可以用来解决实 ...

  2. Kubernetes之DaemonSet

    1.DaemonSet在每个节点上运行一个pod K8s中Replicationcontroller和ReplicaSet都用于在Kubernetes集群上运行部署特定数量的pod.但是,当希望pod ...

  3. k8s学习 - 概念 - ReplicationController

    k8s学习 - 概念 - ReplicationController 我们有了 pod,那么就需要对 pod 进行控制,就是同一个服务的 podv我需要启动几个?如果需要扩容了,怎么办?这里就有个控制 ...

  4. Kubernetes(k8s)控制器(三):ReplicationController

    目录 一.系统环境 二.前言 三.ReplicationController概览 四.ReplicationController工作机制 五.创建ReplicationController 六.扩展r ...

  5. k8s入门系列之guestbook快速部署

    k8s集群以及一些扩展插件已经安装完毕,本篇文章介绍一下如何在k8s集群上快速部署guestbook应用. •实验环境为集群:master(1)+node(4),详细内容参考<k8s入门系列之集 ...

  6. k8s dns 服务安装配置说明

    1. 提前条件 安装k8s 集群 2.  dns  安装配置 安装方式: 使用controller  service controller  脚本: 基于官方改动 apiVersion: v1 kin ...

  7. 第四十四章 微服务CICD(6)- gitlab + jenkins + docker + k8s

    总体流程: 在开发机开发代码后提交到gitlab 之后通过webhook插件触发jenkins进行构建,jenkins将代码打成docker镜像,push到docker-registry 之后将在k8 ...

  8. k8s入门系列之扩展组件(二)kube-ui安装篇

    kube-ui是k8s提供的web管理界面,可以展示节点的内存.CPU.磁盘.Pod.RC.SVC等信息. 1.编辑kube-dashboard-rc.yml定义文件[root@master kube ...

  9. k8s入门系列之扩展组件(一)DNS安装篇

    DNS (domain name system),提供域名解析服务,解决了难于记忆的IP地址问题,以更人性可读可记忆可标识的方式映射对应IP地址. Cluster DNS扩展插件用于支持k8s集群系统 ...

  10. 搭建docker私有仓库,建立k8s集群

    服务器IP角色分布 192.168.5.2 etcd server 192.168.5.2 kubernetes master 192.168.5.3 kubernetes node 192.168. ...

随机推荐

  1. 【Windows】关闭 Ctrl+Alt+Delete 锁屏

    参考百度经验: https://jingyan.baidu.com/article/9158e0005787c3a2541228b3.html Win + R 运行 gpedit.msc

  2. 【Spring-Security】Re02 基础认证流程

    一.权限认证模拟操作: 编写Security配置类: package cn.zeal4j.configuration; import org.springframework.context.annot ...

  3. 电视家APP会员退款了 —— 网络电视APP的合规性处理

    今天打开家里网络电视的时候突然发现"电视家APP"居然无法使用了,随后发现账户关联的银行卡收到退款了,于是好奇的研究了一下这个事情. 由于家里是在农村,闭路电视的图像效果很差,估计 ...

  4. ELT已死,EtLT才是现代数据处理架构的终点!

    提到数据处理,经常有人把它简称为"ETL".但仔细说来,数据处理经历了ETL.ELT.XX ETL(例如,Reverse ETL.Zero-ETL)到现在流行的EtLT架构几次更迭 ...

  5. git的快速入门(含常用指令)

    目录 概念 什么是git git与GitHub有什么区别 提交.仓库.分支 git的使用 从GitHub上下载别人的代码 直接将代码下载到本地 克隆仓库获取代码 将自己的代码上传到GitHub 本文拟 ...

  6. CH07_指针

    CH07_指针 指针的基本概念 作用:可以通过指针间接访问内存 描述: 内存编号是从0开始记录的,一般用十六进制数字表示 可以利用指针变量保存地址 指针变量的定义和使用 语法: 数据类型 * 变量名; ...

  7. LaTeX 几种中文字体的比较

    根据自己的喜好给常见的几个中文字体的打分: 字体选项 字体名 得分 adobe Adobe 宋体 Std 5 fandol FandolSong 0 founder 方正书宋_GBK 10 hanyi ...

  8. 【YashanDB知识库】数据库审计shutdown immediate操作导致数据库异常退出

    [问题分类]功能使用 [关键字]数据库审计,shutdown immediate [问题描述]审计shutdown immediate 操作,数据库作主从切换时会导致数据库异常退出. [问题原因分析] ...

  9. P3792 由乃与大母神原型和偶像崇拜

    题意 给定长为 \(n\) 的数组 \(a\),支持单点修改,\(q\) 次查询区间 \([l,r]\) 是否可以重排为值域上连续的一段. \(n,q\le5\times10^5,a_i\le2.5\ ...

  10. 18 Python如何操作文件?

    本篇是 Python 系列教程第 18 篇,更多内容敬请访问我的 Python 合集 1 打开文件 通常使用内置的 open(文件路径, 模式, encoding="utf-8") ...