Tasks

Step-by-step instructions for performing operations with Kubernetes.

Edit This Page

联邦 ReplicaSet

本指南阐述了如何在联邦控制平面中使用 ReplicaSet 。

在联邦控制平面中的 ReplicaSet (在本指南中称为”联邦 ReplicaSet”) 和传统的 Kubernetes ReplicaSet很相似,提供了一样的功能。在联邦控制平面中创建联邦 ReplicaSet 可以确保在联邦的所有集群中都有预期数量的副本。

Before you begin

创建联邦 ReplicaSet

联邦 ReplicaSet 的 API 和传统的 Kubernetes ReplicaSet API 是 100% 兼容的。您可以通过请求联邦 apiserver 来创建联邦 ReplicaSet。

您可以通过使用 kubectl 运行下面的指令来创建联邦 ReplicaSet

kubectl --context=federation-cluster create -f myrs.yaml

--context=federation-cluster 参数告诉 kubectl 发送请求到联邦 apiserver 而不是某个 Kubernetes 集群。

一旦联邦 ReplicaSet 被创建了,联邦控制平面就会在所有底层 Kubernetes 集群中创建一个 ReplicaSet. 您可以通过检查底层每个集群来对其进行验证,例如:

kubectl --context=gce-asia-east1a get rs myrs

上面的命令假定您在客户端中配置了一个叫做 ‘gce-asia-east1a’ 的上下文,用于请求那个区域的集群。

底层集群中的 ReplicaSet 的副本数将会和联邦 ReplicaSet 的副本数保持一致。联邦控制平面将确保联邦的所有集群都和联邦 ReplicaSet 有同样的副本数。

底层集群中副本的分布

默认情况下,副本在所有底层集群中是均匀分布的。例如:如果您有 3 个注册的集群并且用 spec.replicas = 9 参数创建了一个联邦 ReplicaSet,然后在这 3 个集群中每个 ReplicaSet 的副本数会是 spec.replicas=3 。 如果要修改每个集群中的副本数,您可以在联邦 ReplicaSet 中使用 federation.kubernetes.io/replica-set-preferences 作为注解键值来修改 FederatedReplicaSetPreference

更新联邦 ReplicaSet

您可以像更新 Kubernetes ReplicaSet 一样更新联邦 ReplicaSet。但是,对于联邦 ReplicaSet,您必须发送请求到联邦 apiserver 而不是某个特定的 Kubernetes 集群。联邦控制平面会确保任何时候联邦 ReplicaSet 更新后,它会将对应的 ReplicaSet 更新到所有的底层集群中来和它保持一致。

如果您做了包含副本数量的更改,联邦控制平面将会更改底层集群中的副本数以确保它们的总数和联邦 ReplicaSet 期望的副本数保持一致。

删除联邦 ReplicaSet

您可以像删除 Kubernetes ReplicaSet 一样删除联邦 ReplicaSet 。但是,对于联邦 ReplicaSet ,您必须发送请求到联邦 apiserver 而不是某个特定的 Kubernetes 集群。

例如,您可以使用 kubectl 运行下面的命令来删除联邦 ReplicaSet:

kubectl --context=federation-cluster delete rs myrs

要注意的是这时删除联邦 ReplicaSet 并不会删除底层集群中对应的 ReplicaSet。您必须自己手动删除底层集群中的 ReplicaSet。 我们打算在将来修复这个问题。

Analytics

Create an Issue Edit this Page