Cómo escalar cargas de trabajo con estado

En este documento, se describe cómo escalar las cargas de trabajo con estado existentes que se ejecutan en un clúster de Kubernetes aislado de Google Distributed Cloud (GDC). Debes escalar los pods que se ejecutan en tus cargas de trabajo con estado a medida que evolucionan los requisitos de carga de trabajo de tu contenedor.

Este documento está dirigido a los desarrolladores del grupo de operadores de aplicaciones que son responsables de administrar las cargas de trabajo de las aplicaciones de su organización. Para obtener más información, consulta Públicos de la documentación de Google Distributed Cloud aislado.

Antes de comenzar

Para completar las tareas de este documento, debes tener los siguientes recursos y roles:

  • Para ejecutar comandos en un clúster de Kubernetes, asegúrate de tener los siguientes recursos:

    • Busca el nombre del clúster de Kubernetes o pregúntale a un miembro del grupo de administradores de la plataforma cuál es el nombre del clúster.

    • Accede y genera el archivo kubeconfig para el clúster de Kubernetes si no tienes uno.

    • Usa la ruta de acceso de kubeconfig del clúster de Kubernetes para reemplazar KUBERNETES_CLUSTER_KUBECONFIG en estas instrucciones.

  • Para obtener los permisos necesarios para escalar cargas de trabajo con estado en un clúster compartido, pídele al administrador de IAM de la organización que te otorgue el rol de administrador de espacios de nombres (namespace-admin) en el espacio de nombres de tu proyecto.

  • Para obtener los permisos necesarios para escalar cargas de trabajo con estado en un clúster estándar, pídele al administrador de IAM de tu organización que te otorgue el rol de desarrollador de clústeres (cluster-developer) en un clúster estándar.

Cómo escalar un recurso StatefulSet

Usa la funcionalidad de ajuste de escala de Kubernetes para ajustar de forma adecuada la cantidad de Pods que se ejecutan en tu recurso StatefulSet.

Ajusta manualmente la escala de los Pods de un recurso StatefulSet

Para ajustar manualmente la escala de tu recurso StatefulSet, ejecuta el siguiente comando:

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

Reemplaza lo siguiente:

  • KUBERNETES_CLUSTER_KUBECONFIG: Es el archivo kubeconfig del clúster.

  • NAMESPACE: es el espacio de nombres. En el caso de los clústeres compartidos, debe ser un espacio de nombres del proyecto. En el caso de los clústeres estándares, puede ser cualquier espacio de nombres.

  • STATEFULSET_NAME: Es el nombre del objeto StatefulSet en el que se realizará el ajuste.

  • NUMBER_OF_REPLICAS: Es la cantidad de objetos Pod replicados en el objeto StatefulSet.

Escala los Pods realizando una actualización in situ

Para escalar los Pods de un recurso StatefulSet directamente en el archivo de manifiesto, ejecuta lo siguiente:

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

Reemplaza lo siguiente:

  • KUBERNETES__CLUSTER_KUBECONFIG: Es el archivo kubeconfig del clúster.

  • NAMESPACE: es el espacio de nombres. En el caso de los clústeres compartidos, debe ser un espacio de nombres del proyecto. En el caso de los clústeres estándares, puede ser cualquier espacio de nombres.

  • STATEFULSET_NAME: Es el nombre del objeto StatefulSet en el que se realizará el ajuste.

  • NUMBER_OF_REPLICAS: Es la cantidad de objetos Pod replicados en el objeto StatefulSet.

¿Qué sigue?