Un cluster Kubernetes, qu'est-ce que c'est ?

Copier l'URL

Un cluster Kubernetes est un ensemble de machines (les nœuds) qui permettent d'exécuter des applications conteneurisées. Si vous exécutez Kubernetes, vous exécutez un cluster.

Un cluster comprend au minimum un plan de contrôle avec une ou plusieurs machines de calcul (ou nœuds). Le plan de contrôle est responsable du maintien du cluster dans un état souhaité, c'est-à-dire qu'il vérifie, par exemple, les applications exécutées et les images de conteneurs utilisées. Ce sont les nœuds qui exécutent concrètement les applications et les charges de travail.

Le cluster fournit le principal avantage de Kubernetes, à savoir la possibilité de planifier et d'exécuter des conteneurs au sein d'un groupe de machines, physiques ou virtuelles, sur site ou dans le cloud. Les conteneurs Kubernetes ne sont pas liés à des machines individuelles. Au contraire, ils sont dissociés au sein du cluster.

Un cluster Kubernetes se trouve dans un état souhaité, qui détermine les applications ou autres charges de travail à exécuter, ainsi que les images à utiliser, les ressources qui leur sont allouées et d'autres informations de configuration.

Un état souhaité est défini par des fichiers de configuration constitués de manifestes. Ces manifestes sont des fichiers JSON ou YAML qui permettent de déclarer le type d'application à exécuter et le nombre de réplicas nécessaires pour exécuter un système sain.

C'est l'API Kubernetes qui permet de définir l'état souhaité d'un cluster. Vous pouvez interagir avec le cluster pour définir ou modifier l'état souhaité à partir de la ligne de commande (avec kubectl) ou en utilisant l'API.

Kubernetes se charge ensuite de maintenir votre cluster dans l'état souhaité, de façon automatique. Pour donner un exemple simple, supposons que vous cherchiez à déployer une application avec un état souhaité de « 3 », ce qui signifie que trois réplicas de l'application doivent être exécutés. Si l'un de ces conteneurs tombe en panne, Kubernetes détecte que seuls deux réplicas sont exécutés et en ajoute donc un troisième pour atteindre l'état souhaité.

Vous pouvez également utiliser des modèles Kubernetes pour mettre à l'échelle automatiquement votre cluster en fonction de la charge. 

Plan de contrôle, nœuds, pod... définitions des termes associés à Kubernetes

Nous avons défini un cluster comme étant un ensemble de nœuds. Examinons d'autres éléments de Kubernetes afin de mieux comprendre la fonction d'un cluster.

Plan de contrôle : ensemble de processus qui contrôle les nœuds Kubernetes et assigne toutes les tâches.

Nœuds : machines qui exécutent les tâches qui leur sont assignées par le plan de contrôle.

Pod : un ou plusieurs conteneurs déployés sur un seul nœud. Le pod est l'objet Kubernetes le plus petit et le plus simple.

Service : méthode qui permet d'exposer une application exécutée sur un ensemble de pods en tant que service réseau. Le service dissocie la définition des tâches des pods.

Volume : répertoire contenant des données auxquelles les conteneurs d'un pod peuvent accéder. Un volume Kubernetes a la même durée de vie que le pod dans lequel il se trouve et cette durée de vie dépasse celle de n'importe quel conteneur exécuté dans le pod. Ainsi, les données sont conservées lorsqu'un conteneur redémarre.

Espace de noms : cluster virtuel. Les espaces de noms permettent à Kubernetes de gérer plusieurs clusters (pour plusieurs équipes ou projets) au sein d'un même cluster physique.

Ressources Red Hat

Avec l'émergence des applications cloud-native modernes, les environnements Kubernetes deviennent toujours plus distribués. Ils peuvent être déployés sur de nombreux datacenters, sur site, dans un cloud public et à la périphérie du réseau.

Les entreprises qui souhaitent utiliser Kubernetes à grande échelle ou en production devront posséder plusieurs clusters (pour le développement, les tests et la production) distribués entre différents environnements, et être en mesure de les gérer efficacement.

La gestion des clusters Kubernetes désigne la façon dont une équipe informatique gère un groupe de clusters Kubernetes. 

Red Hat est un leader du secteur et l'un des principaux contributeurs des technologies de conteneurs Open Source, y compris de Kubernetes. Chez Red Hat, nous créons les outils essentiels pour sécuriser, simplifier et mettre à jour automatiquement votre infrastructure de conteneurs. 

Red Hat® OpenShift® est une distribution Kubernetes d'entreprise qui permet de bénéficier d'une plateforme unique et intégrée pour l'exploitation et le développement. La solution Red Hat OpenShift offre aux développeurs le choix des langages, des frameworks, des middlewares et des bases de données, et la possibilité de déployer l'automatisation grâce à l'approche CI/CD afin d'optimiser la productivité.

En vous appuyant sur OpenShift, vous pouvez utiliser Red Hat Advanced Cluster Management et Red Hat Ansible® Automation Platform ensemble pour déployer et gérer efficacement plusieurs clusters Kubernetes dans tous les environnements, y compris ceux de cloud public, sur site et en périphérie.

Découvrez comment Red Hat vous aide à créer et à automatiser des environnements hybrides

 

Hub

Le blog officiel de Red Hat

Découvrez les dernières informations concernant notre écosystème de clients, partenaires et communautés.

Tous les essais de produits Red Hat

Profitez de nos essais gratuits de produits Red Hat pour renforcer votre expérience pratique, préparer une certification ou évaluer l'adéquation d'un produit avec les besoins de votre entreprise.

En savoir plus

Les conteneurs en sandbox, qu'est-ce que c'est ?

Les conteneurs en sandbox isolent un programme du reste du système grâce à des machines virtuelles légères qui lancent les conteneurs dans des pods.

Un plan de contrôle hébergé, qu'est-ce que c'est ?

Les plans de contrôle hébergés permettent d'exécuter des plans de contrôle sur des nœuds plus petits, ce qui réduit le coût des clusters et facilite l'adoption d'une véritable stratégie de cloud hybride.

Red Hat OpenShift et Kubernetes

Red Hat® OpenShift® est une plateforme d'applications basée sur Kubernetes. Il s'agit d'un produit logiciel commercialisé qui s'appuie sur plusieurs projets Open Source.

Conteneurs : ressources recommandées

Articles associés