Implementa cargas de trabajo de Autopilot en la arquitectura Arm

En esta página, se muestra cómo configurar las implementaciones de Google Kubernetes Engine (GKE) Autopilot para solicitar nodos que están respaldados por la arquitectura Arm.

Acerca de la arquitectura Arm en Autopilot

Los clústeres de Autopilot ofrecen clases de procesamiento para las cargas de trabajo que tienen requisitos de hardware específicos. Algunas de estas clases de procesamiento admiten varias arquitecturas de CPU, como amd64 y arm64.

Casos de uso para nodos Arm

Los nodos con arquitectura Arm ofrecen un rendimiento más rentable que los nodos x86 similares. Debes seleccionar Arm para tus cargas de trabajo de Autopilot en situaciones como las siguientes:

  • Tu entorno depende de la arquitectura Arm para la compilación las pruebas.
  • Estás desarrollando aplicaciones para dispositivos Android que se ejecutan en CPU Arm.
  • Usas imágenes multiarquitectura y deseas optimizar los costos mientras ejecutas las cargas de trabajo.

Antes de comenzar

Antes de comenzar, asegúrate de haber realizado las siguientes tareas:

  • Habilita la API de Google Kubernetes Engine.
  • Habilitar la API de Google Kubernetes Engine
  • Si deseas usar Google Cloud CLI para esta tarea, instala y, luego, inicializa gcloud CLI. Si ya instalaste gcloud CLI, ejecuta el comando gcloud components update para obtener la versión más reciente. Es posible que las versiones anteriores de gcloud CLI no admitan la ejecución de los comandos de este documento.
  • Revisa los requisitos y las limitaciones de los nodos Arm.
  • Para usar la ComputeClass autopilot-arm, asegúrate de que tu clúster ejecute la versión 1.35.3-gke.1389000 de GKE o una posterior.
  • Asegúrate de tener una cuota para los C4A, N4A, o Tau T2A tipos de máquinas de Compute Engine.
  • Asegúrate de tener un Pod con una imagen de contenedor compilada para la arquitectura Arm.

Cómo solicitar nodos Arm en Autopilot

Para indicarle a Autopilot que ejecute tus Pods en nodos Arm, usa uno de los siguientes métodos, según tus requisitos. Puedes especificarlos con un nodeSelector o una regla de afinidad de nodos:

  • Para cargas de trabajo de uso general: Solicita la plataforma Arm optimizada para contenedores. Para ello, especifica lo siguiente:
    • cloud.google.com/compute-class: autopilot-arm
    • kubernetes.io/arch: arm64
  • Para cargas de trabajo con requisitos de hardware específicos: Especifica una de las siguientes opciones:

    • kubernetes.io/arch: arm64. De forma predeterminada, GKE coloca Pods en tipos de máquinas C4A para clústeres que ejecutan la versión 1.31.3-gke.1056000 y versiones posteriores. Si el clúster ejecuta una versión anterior, GKE coloca Pods en tipos de máquinas T2A.

    • cloud.google.com/machine-family: ARM_MACHINE_SERIES. Reemplaza ARM_MACHINE_SERIES por una serie de máquinas Arm, como C4A, N4A o T2A. GKE coloca Pods en la serie especificada.

De forma predeterminada, si usas cualquiera de las etiquetas, excepto Performance, GKE coloca otros Pods en el mismo nodo si hay capacidad de disponibilidad en ese nodo. Para solicitar un nodo dedicado para cada Pod, agrega la etiqueta cloud.google.com/compute-class: Performance a tu manifiesto junto con las etiquetas de arquitectura o familia de máquinas. Para obtener más detalles, consulta Cómo optimizar el rendimiento de los Pods de Autopilot eligiendo una serie de máquinas.

También puedes usar la etiqueta Scale-Out con la etiqueta arm64 para solicitar T2A. También puedes solicitar la arquitectura Arm para Pods Spot.

Cuando implementas tu carga de trabajo, Autopilot hace lo siguiente:

  1. Aprovisiona de forma automática los nodos Arm para ejecutar tus Pods.
  2. Genera un taint de forma automática en los nodos nuevos para evitar que se programen Pods que no sean de Arm en esos nodos.
  3. Agrega de forma automática una tolerancia a tus Pods de Arm para permitir la programación en los nodos nuevos.

Solicitud de ejemplo de la arquitectura Arm

En las siguientes especificaciones de ejemplo, se muestra cómo usar un selector de nodos o una regla de afinidad de nodos para solicitar la arquitectura Arm en Autopilot.

nodeSelector

En el siguiente manifiesto de ejemplo, se solicita un nodo Arm optimizado para contenedores de Autopilot:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-arm
spec:
  replicas: 3
  selector:
    matchLabels:
      app: nginx-arm
  template:
    metadata:
      labels:
        app: nginx-arm
    spec:
      nodeSelector:
        cloud.google.com/compute-class: autopilot-arm
        kubernetes.io/arch: arm64
      containers:
      - name: nginx-arm
        image: nginx
        resources:
          requests:
            cpu: 2000m
            memory: 2Gi

Para solicitar hardware específico en lugar de nodos optimizados para contenedores de Autopilot, reemplaza autopilot-arm por Performance o Scale-Out en nodeSelector.

nodeAffinity

Puedes usar la afinidad de nodos para solicitar nodos Arm.

En el siguiente manifiesto de ejemplo, se solicita un nodo Arm optimizado para contenedores de Autopilot:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-arm
spec:
  replicas: 3
  selector:
    matchLabels:
      app: nginx-arm
  template:
    metadata:
      labels:
        app: nginx-arm
    spec:
      terminationGracePeriodSeconds: 25
      containers:
      - name: nginx-arm
        image: nginx
        resources:
          requests:
            cpu: 2000m
            memory: 2Gi
            ephemeral-storage: 1Gi
      affinity:
        nodeAffinity:
          requiredDuringSchedulingIgnoredDuringExecution:
            nodeSelectorTerms:
            - matchExpressions:
              - key: cloud.google.com/compute-class
                operator: In
                values:
                - autopilot-arm
              - key: kubernetes.io/arch
                operator: In
                values:
                - arm64

Para solicitar hardware específico en lugar de nodos optimizados para contenedores de Autopilot, reemplaza autopilot-arm por Performance o Scale-Out en las reglas nodeAffinity.

Recomendaciones

  • Compila y usa imágenes multiarquitectura como parte de tu canalización. Las imágenes multiarquitectura garantizan que tus Pods se ejecuten incluso si se colocan en nodos x86.
  • Solicita arquitectura y clases de procesamiento de forma explícita en tus manifiestos de cargas de trabajo. Si no lo haces, Autopilot usa la arquitectura predeterminada de la clase de procesamiento seleccionada, que podría no ser Arm.

Disponibilidad

Puedes implementar cargas de trabajo de Autopilot en la arquitectura Arm en las siguientes regiones: us-east1, us-west1, europe-west1, europe-west4 y us-central1.

Soluciona problemas

Para obtener información sobre la solución de problemas y errores comunes, consulta Solución de problemas de cargas de trabajo de Arm.

¿Qué sigue?