# Stratégies de déploiements

Lorsqu'on déploie des applications conteneurisées sur un cluster Kubernetes, il est essentiel de choisir la bonne stratégie de déploiement. Voici quelques-unes des stratégies les plus courantes :

**1. Rolling Update (Mise à jour progressive) :**

Cette stratégie met à jour progressivement les instances de l'application sans temps d'arrêt. Les nouvelles versions des pods remplacent les anciennes de manière incrémentale jusqu'à ce que le déploiement soit complet.

**Exemple de configuration YAML pour un&#x20;*****Rolling Update*****&#x20;:**

```yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: frontend-deployment
spec:
  replicas: 3
  strategy:
    type: RollingUpdate
    rollingUpdate:
      maxUnavailable: 1
      maxSurge: 1
  selector:
    matchLabels:
      app: frontend
  template:
    metadata:
      labels:
        app: frontend
    spec:
      containers:
        - name: frontend
          image: myapp/frontend:v2
          ports:
            - containerPort: 80
```

**Explication** : La configuration spécifie que lors de la mise à jour, au maximum 1 pod sera indisponible à la fois (*maxUnavailable: 1*) et 1 pod supplémentaire peut être ajouté temporairement (*maxSurge: 1*).

**2. Blue-Green Deployment :**

Cette stratégie consiste à exécuter deux environnements, *Blue* (l'ancienne version) et *Green* (la nouvelle version), en parallèle. Une fois que l'environnement *Green* est validé, le trafic est basculé de *Blue* à *Green*, ce qui minimise le risque de défaillance.

**Exemple de déploiement Blue-Green :**

```yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: backend-deployment-blue
spec:
  replicas: 2
  selector:
    matchLabels:
      app: backend
      version: blue
  template:
    metadata:
      labels:
        app: backend
        version: blue
    spec:
      containers:
        - name: backend
          image: myapp/backend:v1
          ports:
            - containerPort: 3001

---

apiVersion: apps/v1
kind: Deployment
metadata:
  name: backend-deployment-green
spec:
  replicas: 2
  selector:
    matchLabels:
      app: backend
      version: green
  template:
    metadata:
      labels:
        app: backend
        version: green
    spec:
      containers:
        - name: backend
          image: myapp/backend:v2
          ports:
            - containerPort: 3001
```

**Explication** : Le trafic est initialement dirigé vers la version *Blue*. Une fois la version *Green* prête et validée, le service est configuré pour rediriger le trafic vers *Green*.

**3. Canary Deployment :**

Le déploiement canari consiste à déployer progressivement la nouvelle version à un petit pourcentage des utilisateurs tout en observant les métriques et les performances. Si la version est stable, elle est déployée à l'ensemble des utilisateurs.

**Exemple de configuration YAML pour un déploiement Canari :**

```yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: frontend-canary
spec:
  replicas: 1
  selector:
    matchLabels:
      app: frontend
      version: canary
  template:
    metadata:
      labels:
        app: frontend
        version: canary
    spec:
      containers:
        - name: frontend
          image: myapp/frontend:v3
          ports:
            - containerPort: 80
```

**Explication** : Un pod avec la version *Canary* est déployé pour tester la nouvelle version en conditions réelles.


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://alexiss-organization-12.gitbook.io/documentation-introduction-cloud/etapes/strategies-de-deploiements.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
