Docker et Kubernetes pour développeurs : Guide pratique 2026

Comprendre et maîtriser la conteneurisation n'est plus optionnel en 2026. Voici le guide que j'aurais aimé avoir quand j'ai commencé.

Pourquoi conteneuriser ?

Les conteneurs résolvent le fameux "ça marche sur ma machine" :

Docker : Les bases

Dockerfile

Le Dockerfile décrit comment construire votre image :

# Image de base
FROM python:3.11-slim

# Répertoire de travail
WORKDIR /app

# Copier les dépendances
COPY requirements.txt .
RUN pip install --no-cache-dir -r requirements.txt

# Copier le code
COPY . .

# Port exposé
EXPOSE 8000

# Commande de démarrage
CMD ["uvicorn", "main:app", "--host", "0.0.0.0", "--port", "8000"]

Commandes essentielles

# Construire une image
docker build -t mon-app:v1 .

# Lancer un conteneur
docker run -d -p 8000:8000 --name mon-app mon-app:v1

# Voir les conteneurs actifs
docker ps

# Logs d'un conteneur
docker logs mon-app

# Arrêter et supprimer
docker stop mon-app && docker rm mon-app

Docker Compose

Pour orchestrer plusieurs conteneurs localement :

version: '3.8'
services:
  api:
    build: .
    ports:
      - "8000:8000"
    environment:
      - DATABASE_URL=postgresql://user:pass@db:5432/mydb
    depends_on:
      - db

  db:
    image: postgres:15
    environment:
      - POSTGRES_USER=user
      - POSTGRES_PASSWORD=pass
      - POSTGRES_DB=mydb
    volumes:
      - postgres_data:/var/lib/postgresql/data

volumes:
  postgres_data:

Kubernetes : L'orchestration

Kubernetes (K8s) gère le déploiement, le scaling et la disponibilité de vos conteneurs en production.

Concepts clés

Exemple de Deployment

apiVersion: apps/v1
kind: Deployment
metadata:
  name: mon-api
spec:
  replicas: 3
  selector:
    matchLabels:
      app: mon-api
  template:
    metadata:
      labels:
        app: mon-api
    spec:
      containers:
      - name: api
        image: mon-registry/mon-api:v1
        ports:
        - containerPort: 8000
        resources:
          requests:
            memory: "128Mi"
            cpu: "100m"
          limits:
            memory: "256Mi"
            cpu: "500m"
        env:
        - name: DATABASE_URL
          valueFrom:
            secretKeyRef:
              name: db-secret
              key: url

Service et Ingress

apiVersion: v1
kind: Service
metadata:
  name: mon-api-service
spec:
  selector:
    app: mon-api
  ports:
  - port: 80
    targetPort: 8000
---
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: mon-api-ingress
spec:
  rules:
  - host: api.mondomaine.com
    http:
      paths:
      - path: /
        pathType: Prefix
        backend:
          service:
            name: mon-api-service
            port:
              number: 80
Conseil : Commencez par Docker seul. Kubernetes n'est nécessaire que si vous avez besoin de scaling automatique, haute disponibilité ou orchestration multi-services complexe. Pour un projet simple, Docker Compose suffit.

Bonnes pratiques

Conclusion

Docker et Kubernetes sont des compétences essentielles en 2026. Maîtrisez d'abord Docker, puis passez à Kubernetes quand vos besoins le justifient.

Besoin d'aide pour conteneuriser vos applications ? Découvrez mes services DevOps.

Davy Abderrahman

Davy Abderrahman

Expert DevOps, Docker & Kubernetes. Certifications AWS et Azure.

En savoir plus