Kubernetes 之 ReplicaSet

部署运行你感兴趣的模型镜像

ReplicaSet(简称RS)

ReplicationController(简称RC) 用来确保容器应用的副本数始终保持在用户定义的副本数,即如果有容器异常退出,会自动创建新的 Pod 来替代;而如果异常多出来的容器也会自动回收。

在新版本的 Kubernetes 中建议使用 ReplicaSet 来取代 ReplicationControllerReplicaSet 跟 ReplicationController 没有本质的不同,只是名字不一样,并且 ReplicaSet 支持集合式的 Selector(选择器)

虽然 ReplicaSet 可以独立使用,但一般还是建议使用Deployment来自动管理 ReplicaSet,这样就无需担心跟其他机制的不兼容问题(比如 ReplicaSet 不支持 rolling-update ,但 Deployment 支持)

ReplicationController 和 ReplicaSet 区别

ReplicationController 和 ReplicaSet 的行为是完全相同的,但是 ReplicaSet 的 Pod 选择器表达能力更强。

  • ReplicationController 只允许包含某个标签的匹配 Pod
  • ReplicaSet 可以包含特定标签名的 Pod ,例如 env=dev 和 env=pro 一起匹配。
  • ReplicaSet 还可以匹配缺少某个标签的 Pod

总之,无论 ReplicationController 匹配的标签值是多少,ReplicationController 都无法基于标签名来进行匹配,例如:匹配env=* 。但是 ReplicaSet 可以。

ReplicaSet 案例

kubia-rs.yaml

 

yaml

复制代码

apiVersion: apps/v1 kind: ReplicaSet metadata: name: kubia-rs spec: replicas: 3 # 副本数 3 个 selector: matchLabels: app: xmt-kubia # 选择器指定匹配标签 template: metadata: labels: app: xmt-kubia spec: containers: - name: rs-kubia image: xiaomotong888/xmtkubia # 模板拉取的镜像 ports: - containerPort: 8080

部署 rs

 

yaml

复制代码

# 创建rs kubectl create -f kubia-rs.yaml # 查看新建的 rs 基本信息 kubectl get rs

运行结果:

对于原本就有的 3 个标签为 app=xmt-kubia 的 Pod 没有影响, rs 也没有多创建 Pod ,这没问题。 rs也是会去搜索环境内的匹配的标签对应的 Pod 个数,然后和自己配置中的期望做比较,若期望的大,则增加 Pod 数量,若期望的小,则减少 Pod 数量。

删除 rs

删除 rs 的时候和删除 rc 的做法是一样的,默认的话都是会删除掉 rs 管理的 Pod ,如果我们不需要删除对应的 Pod ,那么我们也可以加入 --cascade=false 或者 –cascade=orphan

按照上述方式指定之后,删除 rs ,就不会对 Pod 有任何影响。

您可能感兴趣的与本文相关的镜像

GPT-SoVITS

GPT-SoVITS

AI应用

GPT-SoVITS 是一个开源的文本到语音(TTS)和语音转换模型,它结合了 GPT 的生成能力和 SoVITS 的语音转换技术。该项目以其强大的声音克隆能力而闻名,仅需少量语音样本(如5秒)即可实现高质量的即时语音合成,也可通过更长的音频(如1分钟)进行微调以获得更逼真的效果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值