CRI agit comme un pont entre Kubernetes et le runtime de conteneur, définissant un ensemble standard d'appels gRPC que Kubernetes utilise pour interagir avec les conteneurs. Cette couche d'abstraction est ce qui nous permet de remplacer Docker par d'autres runtimes sans que Kubernetes ne fasse des siennes.

CRI-O : La Machine de Conteneur Efficace et Légère

Le premier dans notre liste d'alternatives à Docker est CRI-O. Né des efforts collaboratifs de Red Hat, Intel, SUSE et IBM, CRI-O est comme ce cousin surdoué qui semble toujours tout faire correctement.

Pourquoi CRI-O ?

  • Léger et conçu spécialement pour Kubernetes
  • Conforme à l'OCI (Open Container Initiative)
  • Prend en charge plusieurs formats d'image
  • Met l'accent sur la sécurité et la stabilité

Commencer avec CRI-O

Mettons les mains dans le cambouis et configurons un cluster Kubernetes en utilisant CRI-O. Tout d'abord, nous devons installer CRI-O sur nos nœuds :


# Définir la distribution OS
OS=xUbuntu_20.04

# Définir la version de CRI-O
VERSION=1.23

# Ajouter le dépôt CRI-O
echo "deb https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable/$OS/ /" > /etc/apt/sources.list.d/devel:kubic:libcontainers:stable.list
echo "deb http://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable:/cri-o:/$VERSION/$OS/ /" > /etc/apt/sources.list.d/devel:kubic:libcontainers:stable:cri-o:$VERSION.list

# Importer la clé GPG
curl -L https://download.opensuse.org/repositories/devel:kubic:libcontainers:stable:cri-o:$VERSION/$OS/Release.key | apt-key add -
curl -L https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable/$OS/Release.key | apt-key add -

# Mettre à jour et installer CRI-O
apt-get update
apt-get install cri-o cri-o-runc

Maintenant que nous avons installé CRI-O, configurons Kubernetes pour l'utiliser. Lors de l'initialisation de votre cluster Kubernetes avec kubeadm, utilisez la commande suivante :


kubeadm init --cri-socket=/var/run/crio/crio.sock

Et voilà ! Vous exécutez maintenant Kubernetes avec CRI-O. Mais comment se comporte-t-il par rapport à Docker ?

Comparaison des Performances

Dans nos tests, nous avons constaté que CRI-O surpasse généralement Docker en termes de temps de démarrage des conteneurs et d'utilisation des ressources. Voici un aperçu rapide :

Métrique Docker CRI-O
Temps de démarrage des conteneurs 300ms 250ms
Utilisation de la mémoire (au repos) 50MB 30MB
Utilisation du CPU (au repos) 0.5% 0.3%

Ces chiffres peuvent sembler petits, mais ils peuvent s'accumuler de manière significative dans des déploiements à grande échelle.

containerd : Le Cheval de Trait Silencieux

Ensuite, nous avons containerd, le runtime qui alimente discrètement Docker lui-même depuis des années. C'est comme le moteur de votre voiture - vous n'y pensez peut-être pas beaucoup, mais il fait tout le gros du travail.

Pourquoi containerd ?

  • Éprouvé en environnements de production
  • Modulaire et extensible
  • Forte communauté de soutien
  • Support natif dans les principaux fournisseurs de cloud

Configuration de containerd

Configurons un cluster Kubernetes en utilisant containerd. Tout d'abord, nous devons l'installer :


# Installer containerd
apt-get update && apt-get install -y containerd

# Configurer containerd et démarrer le service
mkdir -p /etc/containerd
containerd config default > /etc/containerd/config.toml
systemctl restart containerd

Maintenant, initialisons notre cluster Kubernetes avec containerd :


kubeadm init --cri-socket=/run/containerd/containerd.sock

Considérations de Compatibilité

Bien que containerd soit généralement très compatible avec Docker, il y a quelques points à garder à l'esprit :

  • Les commandes spécifiques à Docker ne fonctionneront pas directement avec containerd
  • Certaines fonctionnalités spécifiques à Docker (comme Docker Compose) peuvent nécessiter des alternatives
  • La création d'images peut nécessiter des outils différents (comme buildah ou kaniko)

L'Éléphant (ou la Baleine) dans la Pièce : Qu'en est-il de Docker ?

Vous vous demandez peut-être, "Si ces alternatives sont si bonnes, pourquoi Docker a-t-il été le choix privilégié si longtemps ?" Eh bien, Docker a fait beaucoup de choses correctement :

  • Il a rendu les conteneurs accessibles et faciles à utiliser
  • Il a fourni un écosystème complet (Docker Hub, Docker Compose, etc.)
  • Il avait (et a toujours) une communauté massive et une richesse de ressources

Mais à mesure que Kubernetes a gagné en popularité et en maturité, le besoin d'un runtime plus spécialisé et léger est devenu évident. C'est là que CRI-O et containerd brillent.

Faire le Changement : Défis et Solutions

Passer de Docker à un runtime alternatif n'est pas sans défis. Voici quelques obstacles courants et comment les surmonter :

1. Compatibilité des Images

Défi : Certaines images Docker peuvent ne pas fonctionner immédiatement avec des runtimes alternatifs.

Solution : Utilisez des images conformes à l'OCI et des outils comme Buildah ou Kaniko pour la création d'images.

2. Flux de Travail des Développeurs

Défi : Les développeurs habitués à l'interface CLI de Docker peuvent avoir du mal avec la transition.

Solution : Introduisez des outils comme Podman qui offrent une expérience CLI similaire à Docker tout en travaillant avec CRI-O ou containerd en arrière-plan.

3. Surveillance et Journalisation

Défi : Les solutions de surveillance existantes peuvent être étroitement liées à Docker.

Solution : Utilisez des solutions de surveillance natives à Kubernetes comme Prometheus et Grafana, qui fonctionnent bien avec n'importe quel runtime compatible CRI.

Le Verdict : Docker ou Pas Docker ?

Après notre exploration pratique, il est clair que CRI-O et containerd sont des alternatives viables à Docker pour gérer des clusters Kubernetes. Ils offrent de meilleures performances, une intégration plus étroite avec Kubernetes et un ensemble de fonctionnalités plus ciblé.

Cependant, la décision de changer doit être basée sur votre cas d'utilisation spécifique. Si vous démarrez un nouveau projet Kubernetes, opter pour CRI-O ou containerd dès le départ pourrait vous éviter des maux de tête plus tard. Pour les déploiements existants, pesez soigneusement les avantages par rapport à l'effort requis pour la migration.

En Conclusion : L'Avenir est Conteneurisé (Mais Pas Nécessairement Dockerisé)

Comme nous l'avons vu, le monde des runtimes de conteneurs évolue au-delà de Docker. CRI-O et containerd offrent des alternatives convaincantes qui peuvent améliorer les performances et l'efficacité de vos clusters Kubernetes.

Rappelez-vous, le but n'est pas de suivre la dernière tendance, mais de choisir les outils qui conviennent le mieux à vos besoins. Que vous restiez avec Docker ou que vous fassiez le saut vers une alternative, l'essentiel est de continuer à conteneuriser, orchestrer et innover.

Maintenant, allez de l'avant et contenez le monde ! (Peut-être juste sans la baleine cette fois.)

"Le meilleur runtime est celui auquel vous n'avez pas à penser." - Probablement chaque ingénieur DevOps

Lectures Complémentaires

Avez-vous fait le changement de Docker dans vos clusters Kubernetes ? Partagez vos expériences dans les commentaires ci-dessous !