AWS.Compute. EKSManagedNodo - AWS Creador de redes de telecomunicaciones

Las traducciones son generadas a través de traducción automática. En caso de conflicto entre la traducción y la version original de inglés, prevalecerá la version en inglés.

AWS.Compute. EKSManagedNodo

AWS TNB es compatible con los grupos de nodos gestionados por EKS para automatizar el aprovisionamiento y la administración del ciclo de vida de los nodos ( EC2 instancias de Amazon) para los clústeres de Amazon EKS Kubernetes. Para crear un grupo de nodos EKS, haga lo siguiente:

  • Elija Amazon Machine Images (AMI) para los nodos de trabajo de su clúster proporcionando el ID de la AMI o el tipo de AMI.

  • Proporcione un par de EC2 claves de Amazon para el acceso SSH y las propiedades de escalado de su grupo de nodos.

  • Asegúrese de que su grupo de nodos esté asociado a un clúster de Amazon EKS.

  • Proporcione las subredes de los nodos de trabajo.

  • Si lo desea, adjunte grupos de seguridad, etiquetas de nodos y un grupo de ubicación a su grupo de nodos.

Sintaxis

tosca.nodes.AWS.Compute.EKSManagedNode: capabilities: compute: properties: ami_type: String ami_id: String instance_types: List key_pair: String root_volume_encryption: Boolean root_volume_encryption_key_arn: String scaling: properties: desired_size: Integer min_size: Integer max_size: Integer properties: node_role: String tags: List kubernetes_version: String requirements: cluster: String subnets: List network_interfaces: List security_groups: List placement_group: String user_data: String labels: List

Capacidades

compute

Propiedades que definen los parámetros informáticos del grupo de nodos gestionado por Amazon EKS, como los tipos de EC2 instancias de Amazon y la EC2 instancia de Amazon AMIs.

ami_type

El tipo de AMI compatible con Amazon EKS.

Obligatorio: sí

Tipo: cadena

Valores posibles: AL2_x86_64 | AL2_x86_64_GPU | AL2_ARM_64 | CUSTOM | BOTTLEROCKET_ARM_64 | BOTTLEROCKET_x86_64 | BOTTLEROCKET_ARM_64_NVIDIA | BOTTLEROCKET_x86_64_NVIDIA

ami_id

Es el ID de la AMI.

Obligatorio: no

Tipo: cadena

nota

Si ambos ami_type y ami_id se especifican en la plantilla, AWS TNB utilizará solo el ami_id valor para crear. EKSManagedNode

instance_types

El tamaño de la instancia.

Obligatorio: sí

Tipo: lista

key_pair

El par de EC2 claves para habilitar el acceso SSH.

Obligatorio: sí

Tipo: cadena

root_volume_encryption

Habilita el cifrado de Amazon EBS para el volumen raíz de Amazon EBS. Si no se proporciona esta propiedad, AWS TNB cifra los volúmenes raíz de Amazon EBS de forma predeterminada.

Obligatorio: no

Predeterminado: true

Tipo: Booleano

root_volume_encryption_key_arn

El ARN de la AWS KMS clave. AWS TNB admite el ARN de clave normal, el ARN de clave multirregional y el ARN de alias.

Obligatorio: no

Tipo: cadena

nota
  • Si root_volume_encryption es falso, no lo incluya. root_volume_encryption_key_arn

  • AWS TNB admite el cifrado del volumen raíz de las AMI respaldadas por Amazon EBS.

  • Si el volumen raíz de la AMI ya está cifrado, debe incluirlo root_volume_encryption_key_arn para que AWS TNB vuelva a cifrar el volumen raíz.

  • Si el volumen raíz de la AMI no está cifrado, AWS TNB lo utiliza root_volume_encryption_key_arn para cifrar el volumen raíz.

    Si no la incluyeroot_volume_encryption_key_arn, AWS TNB utilizará la clave predeterminada proporcionada por AWS Key Management Service para cifrar el volumen raíz.

  • AWS TNB no descifra una AMI cifrada.

scaling

Propiedades que definen los parámetros de escalado del grupo de nodos gestionado por Amazon EKS, como el número deseado de EC2 instancias de Amazon y el número mínimo y máximo de EC2 instancias de Amazon en el grupo de nodos.

desired_size

El número de instancias que contiene NodeGroup.

Obligatorio: sí

Tipo: entero

min_size

El número mínimo de instancias que contiene NodeGroup.

Obligatorio: sí

Tipo: entero

max_size

El número máximo de instancias que contiene NodeGroup.

Obligatorio: sí

Tipo: entero

Propiedades

node_role

El ARN del rol de IAM adjunto a la instancia de Amazon. EC2

Obligatorio: sí

Tipo: cadena

tags

Las etiquetas que deben asociarse al recurso.

Obligatorio: no

Tipo: lista

kubernetes_version

La versión de Kubernetes para el grupo de nodos gestionados. AWS TNB es compatible con las versiones 1.23 a 1.30 de Kubernetes. Considere lo siguiente:

  • Especifique la kubernetes_version ami_id opción o. No especifique ambos.

  • kubernetes_versionDebe ser menor o igual que AWS.Compute. EKSManagedVersión de nodo.

  • Puede haber una diferencia de 3 versiones entre el AWS.Compute. EKSManagedVersión de nodo y. kubernetes_version

  • Si no ami_id se kubernetes_version especifica ni, AWS TNB utilizará la AMI más reciente de la AWS.Compute.EKSManagedNode versión para crear EKSManagedNode

Obligatorio: no

Tipo: cadena

Valores posibles: 1,23 | 1,24 | 1,25 | 1,26 | 1,27 | 1,28 | 1,29 | 1,30

Requisitos

cluster

Un nodo AWS.Compute.EKS.

Obligatorio: sí

Tipo: cadena

subnets

Un nodo AWS.Networking.Subnet.

Obligatorio: sí

Tipo: lista

network_interfaces

Un nodo AWS.Networking.ENI. Asegúrese de que las interfaces de red y las subredes estén configuradas en la misma zona de disponibilidad o se producirá un error en la instanciación.

Al configurarlonetwork_interfaces, AWS TNB obtiene el permiso correspondiente de la multus_role propiedad si la ha incluido en el nodo ENIs AWS.Compute.EKS. multus De lo contrario, AWS TNB obtiene el permiso correspondiente de la propiedad node_role. ENIs

Obligatorio: no

Tipo: lista

security_groups

Un .Networking.AWS SecurityGroupnodo.

Obligatorio: no

Tipo: lista

placement_group

Un tosca.nodes.AWS.Compute. PlacementGroupnodo.

Obligatorio: no

Tipo: cadena

user_data

Un tosca.nodes.AWS.Compute. UserDatareferencia de nodo. Se pasa un script de datos de usuario a las EC2 instancias de Amazon lanzadas por el grupo de nodos gestionado. Agregue los permisos necesarios para ejecutar datos de usuario personalizados al node_role pasado al grupo de nodos.

Obligatorio: no

Tipo: cadena

labels

Una lista de etiquetas de nodos. Una etiqueta de nodo debe tener un nombre y un valor. Cree una etiqueta con los siguientes criterios:

  • El nombre y el valor deben estar separados por=.

  • El nombre y el valor pueden tener hasta 63 caracteres cada uno.

  • La etiqueta puede incluir letras (A-Z, a-z), números (0-9) y los siguientes caracteres: [-, _, ., *, ?]

  • El nombre y el valor deben empezar y terminar con un alfanumérico o un carácter. ? *

Por ejemplo, myLabelName1=*NodeLabelValue1 .

Obligatorio: no

Tipo: lista

Ejemplo

SampleEKSManagedNode: type: tosca.nodes.AWS.Compute.EKSManagedNode capabilities: compute: properties: ami_type: "AL2_x86_64" instance_types: - "t3.xlarge" key_pair: "SampleKeyPair" root_volume_encryption: true root_volume_encryption_key_arn: "arn:aws:kms:us-west-2:111122223333:key/1234abcd-12ab-34cd-56ef-1234567890ab" scaling: properties: desired_size: 1 min_size: 1 max_size: 1 properties: node_role: "arn:aws:iam::${AWS::TNB::AccountId}:role/SampleRole" tags: - "Name=SampleVPC" - "Environment=Testing" kubernetes_version: - "1.30" requirements: cluster: SampleEKS subnets: - SampleSubnet network_interfaces: - SampleENI01 - SampleENI02 security_groups: - SampleSecurityGroup01 - SampleSecurityGroup02 placement_group: SamplePlacementGroup user_data: CustomUserData labels: - "sampleLabelName001=sampleLabelValue001" - "sampleLabelName002=sampleLabelValue002"