Choix du type d’instance Amazon EC2 optimal pour les nœuds - Amazon EKS

Aidez à améliorer cette page

Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.

Pour contribuer à ce guide de l'utilisateur, cliquez sur le GitHub lien Modifier cette page sur qui se trouve dans le volet droit de chaque page.

Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.

Choix du type d’instance Amazon EC2 optimal pour les nœuds

Amazon EC2 fournit un large choix de types d'instance pour les composants master. Chaque type d'instance offre des capacités de calcul, de mémoire, de stockage et de réseau différentes. Chaque instance est également regroupée dans une famille d'instances en fonction de ces capacités. Pour la liste complète, consultez Types d’instances disponibles dans le Guide de l’utilisateur Amazon EC2. Amazon EKS publie plusieurs variantes d'Amazon EC2 AMIs pour permettre le support. Pour vous assurer que le type d'instance que vous sélectionnez est compatible avec Amazon EKS, tenez compte des critères suivants.

  • Tous les Amazon EKS AMIs ne prennent actuellement pas en charge mac cette famille.

  • Arm et Amazon EKS non accéléré AMIs ne prennent pas en charge lesg3, g4inf, et p les familles.

  • Amazon EKS accéléré AMIs ne prend pas en charge les ac,hpc,m, et t les familles.

  • Pour les instances basées sur ARM, Amazon Linux 2023 (AL2023) ne prend en charge que les types d'instances qui utilisent des processeurs Graviton2 ou version ultérieure. AL2023 ne prend pas en charge A1 les instances.

Lorsque vous choisissez entre les types d'instances pris en charge par Amazon EKS, tenez compte des fonctionnalités suivantes de chaque type.

Nombre d'instances dans un groupe de nœuds

De manière générale, il est préférable d’utiliser moins d’instances, mais plus grandes, surtout si vous avez de nombreux DaemonSets. Chaque instance nécessitant des appels API vers le serveur d'API, plus le nombre d'instances est élevé, plus la charge sur le serveur d'API est importante.

Système d’exploitation

Examinez les types d'instances pris en charge pour LinuxWindows et Bottlerocket. Avant de créer des instances Windows, consultez Déploiement de nœuds Windows sur les clusters EKS.

Architecture matérielle

Avez-vous besoin d’une architecture x86 ou Arm ? Avant de déployer des instances Arm, consultez Arm Amazon Linux optimisé pour Amazon EKS AMIs. Avez-vous besoin d’instances basées sur le système Nitro (Linux ou Windows) ou disposant de capacités accélérées ? Si vous avez besoin de fonctionnalités accélérées, vous ne pouvez utiliser Linux qu'avec Amazon EKS.

Nombre maximal de pods

Comme chaque pod reçoit sa propre adresse IP, le nombre d’adresses IP prises en charge par un type d’instance est un facteur déterminant pour savoir combien de pods peuvent s’exécuter sur cette instance. Pour déterminer manuellement combien de pods un type d’instance peut prendre en charge, consultez .

AWS Les types d'instances Nitro System prennent éventuellement en charge un plus grand nombre d'adresses IP que les types d'instances autres que Nitro System. Cependant, toutes les adresses IP attribuées à une instance ne sont pas disponibles pour les pods. Pour attribuer un nombre significativement plus élevé d'adresses IP à vos instances, la version 1.9.0 ou ultérieure du module complémentaire Amazon VPC CNI doit être installée dans votre cluster et configurée de manière appropriée. Pour de plus amples informations, veuillez consulter Attribution de davantage d’adresses IP aux nœuds Amazon EKS avec des préfixes. Pour attribuer le plus grand nombre d'adresses IP à vos instances, vous devez avoir installé la version 1.10.1 ou une version ultérieure du module complémentaire Amazon VPC CNI dans votre cluster et déployer le cluster avec la famille IPv6.

Famille IP

Vous pouvez utiliser n’importe quel type d’instance pris en charge lorsque vous utilisez la famille IPv4 pour un cluster, ce qui permet à votre cluster d’attribuer des adresses IPv4 privées à vos pods et services. Mais si vous souhaitez utiliser la famille IPv6 pour votre cluster, alors vous devez utiliser les types d'instance AWS Nitro System ou les types d'instance matériel nu. Seul IPv4 est pris en charge pour les instances Windows. Votre cluster doit utiliser la version 1.10.1 ou une version ultérieure du module complémentaire Amazon VPC CNI. Pour plus d'informations sur l'utilisation de IPv6, consultez En savoir plus sur IPv6 les adresses des clusters, des pods et des services.

Version du module complémentaire Amazon VPC CNI que vous exécutez

La dernière version du plug-in CNI Amazon VPC pour Kubernetes prend en charge ces types d'instance. Il peut être nécessaire de mettre à jour la version de votre module complémentaire CNI Amazon VPC pour bénéficier des derniers types d'instance pris en charge. Pour de plus amples informations, veuillez consulter Attribuer IPs à des pods avec l'Amazon VPC CNI. La dernière version prend en charge les dernières fonctions pour une utilisation avec Amazon EKS. Les versions antérieures ne prennent pas en charge toutes les fonctionnalités. Vous pouvez afficher les fonctions prises en charge par les différentes versions dans Changelog sur GitHub.

Région  AWS dans laquelle vous créez vos nœuds

Tous les types d'instances ne sont pas disponibles dans toutes les AWS régions.

Si vous utilisez des groupes de sécurité pour les pods

Si vous utilisez des groupes de sécurité pour les pods, seuls certains types d’instances sont pris en charge. Pour de plus amples informations, veuillez consulter Attribution de groupes de sécurité à des pods individuels.

Comment est déterminé MaxPods

La maxPods valeur finale appliquée à un nœud dépend de plusieurs composants qui interagissent dans un ordre de priorité spécifique. La compréhension de cet ordre vous permet d'éviter les comportements inattendus lors de la personnalisationmaxPods.

Ordre de priorité (du plus élevé au plus bas) :

  1. Application des groupes de nœuds gérés : lorsque vous utilisez un groupe de nœuds gérés sans AMI personnalisée, Amazon EKS impose un plafonnement maxPods des données utilisateur du nœud. Pour les instances avec moins de 30 VCPUs, le plafond est110. Pour les instances avec une tension supérieure à 30 VCPUs, le plafond est fixé à250. Cette valeur a priorité sur toute autre maxPods configuration, y comprismaxPodsExpression.

  2. maxPodsconfiguration kubelet — Si vous définissez maxPods directement dans la configuration kubelet (par exemple, via un modèle de lancement avec une AMI personnalisée), cette valeur a priorité sur. maxPodsExpression

  3. nodeadm maxPodsExpression — Si vous utilisez maxPodsExpressionin yourNodeConfig, nodeadm évalue l'expression à calculer. maxPods Cela n'est efficace que lorsque la valeur n'est pas déjà définie par une source de priorité supérieure.

  4. Calcul par défaut basé sur l'ENI : si aucune autre valeur n'est définie, l'AMI calcule en maxPods fonction du nombre d'interfaces réseau élastiques et d'adresses IP prises en charge par le type d'instance. Cela équivaut à la formule(number of ENIs × (IPs per ENI − 1)) + 2. Les + 2 comptes Amazon VPC CNI s'kube-proxyexécutent sur chaque nœud, qui ne consomment pas d'adresse IP de pod.

Important

Si vous utilisez un groupe de nœuds gérés et que vous le définissez maxPodsExpression dans votreNodeConfig, l'application du groupe de nœuds gérés remplace votre expression. Pour utiliser une maxPods valeur personnalisée avec des groupes de nœuds gérés, vous devez spécifier une AMI personnalisée dans votre modèle de lancement et la définir maxPods directement. Pour de plus amples informations, veuillez consulter Personnaliser les nœuds gérés à l’aide de modèles de lancement.

Groupes de nœuds gérés et nœuds autogérés

Avec les groupes de nœuds gérés (sans AMI personnalisée), Amazon EKS injecte la maxPods valeur dans les données utilisateur bootstrap du nœud. Autrement dit :

  • La maxPods valeur est toujours plafonnée à 110 ou 250 en fonction de la taille de l'instance.

  • Toute configuration maxPodsExpression que vous configurez est remplacée par cette valeur injectée.

  • Pour utiliser une maxPods valeur différente, spécifiez une AMI personnalisée dans votre modèle de lancement et --use-max-pods false transmettez-la --kubelet-extra-args '--max-pods=my-value' au bootstrap.sh script. Pour obtenir des exemples, consultez Personnaliser les nœuds gérés à l’aide de modèles de lancement.

Avec les nœuds autogérés, vous avez un contrôle total sur le processus d'amorçage. Vous pouvez l'utiliser maxPodsExpression dans votre NodeConfig ou le passer --max-pods directement àbootstrap.sh.

Considérations relatives au mode automatique EKS

Le mode automatique EKS limite le nombre de pods sur les nœuds à la plus faible des deux valeurs suivantes :

  • Plafond strict de 110 pods

  • Le résultat du calcul du nombre maximal de pods décrit ci-dessus.