扩缩有状态工作负载

本文档介绍了如何扩缩在 Google Distributed Cloud (GDC) 气隙 Kubernetes 集群中运行的现有有状态工作负载。您必须根据容器工作负载要求的变化来扩缩有状态工作负载中运行的 pod。

本文档适用于应用运维人员群组中的开发者,他们负责管理组织的应用工作负载。如需了解详情,请参阅 GDC 气隙环境的受众群体文档

准备工作

如需完成本文档中的任务,您必须拥有以下资源和角色:

  • 如需针对 Kubernetes 集群运行命令,请确保您拥有以下资源:

    • 找到 Kubernetes 集群名称,或向平台管理员群组的成员询问集群名称。

    • 登录并生成 Kubernetes 集群的 kubeconfig 文件(如果您还没有)。

    • 使用 Kubernetes 集群的 kubeconfig 路径替换这些说明中的 KUBERNETES_CLUSTER_KUBECONFIG

  • 如需获得在共享集群中扩缩有状态工作负载所需的权限,请让组织 IAM 管理员向您授予项目命名空间中的 Namespace Admin 角色 (namespace-admin)。

  • 如需获得在标准集群中扩缩有状态工作负载所需的权限,请让组织 IAM 管理员在标准集群中为您授予 Cluster Developer 角色 (cluster-developer)。

扩缩 StatefulSet 资源

使用 Kubernetes 的伸缩功能来适当伸缩 StatefulSet 资源中运行的 pod 数量。

手动扩缩 StatefulSet 资源的 pod

如需手动扩缩 StatefulSet 资源,请运行以下命令:

kubectl --kubeconfig KUBERNETES__CLUSTER_KUBECONFIG -n NAMESPACE \
    scale statefulset STATEFULSET_NAME \
    --replicas NUMBER_OF_REPLICAS

替换以下内容:

  • KUBERNETES_CLUSTER_KUBECONFIG:集群的 kubeconfig 文件。

  • NAMESPACE:命名空间。对于共享集群,这必须是项目命名空间。对于标准集群,它可以是任何命名空间。

  • STATEFULSET_NAME:要缩放的 StatefulSet 对象的名称。

  • NUMBER_OF_REPLICASStatefulSet 对象中复制的 Pod 对象的数量。

通过执行就地更新来扩缩 Pod

如需直接在清单文件中扩缩 StatefulSet 资源的 pod,请运行以下命令:

kubectl --kubeconfig KUBERNETES__CLUSTER_KUBECONFIG -n NAMESPACE \
    patch statefulsets STATEFULSET_NAME \
    -p '{"spec":{"replicas":NUMBER_OF_REPLICAS}}'

替换以下内容:

  • KUBERNETES__CLUSTER_KUBECONFIG:集群的 kubeconfig 文件。

  • NAMESPACE:命名空间。对于共享集群,这必须是项目命名空间。对于标准集群,它可以是任何命名空间。

  • STATEFULSET_NAME:要缩放的 StatefulSet 对象的名称。

  • NUMBER_OF_REPLICASStatefulSet 对象中复制的 Pod 对象的数量。

后续步骤