Implementing Blue/Green and Canary Deployments in Kubernetes for Zero Downtime

3 min read

Implementing Blue/Green or Canary Deployments in Kubernetes

Deploying updates to applications in a reliable, controlled manner is critical for minimizing downtime and ensuring application stability. In Kubernetes, two popular deployment strategies—Blue/Green and Canary deployments—help achieve this. Both strategies allow you to release new versions of applications with minimal disruption, but they do so in different ways.

This guide will cover the concepts of Blue/Green and Canary Deployments, how to implement them in Kubernetes, and the differences between the two.

What are Blue/Green and Canary Deployments?

Blue/Green Deployment:

Blue/Green deployment involves running two separate but identical environments—Blue (current production) and Green (new version). Traffic is routed to the Green environment only when it’s fully ready, minimizing downtime and reducing the risk of errors.

  • Blue Environment: The existing production environment.
  • Green Environment: The new version of the application, which is identical to Blue but contains new changes or features.
  • Traffic Switching: After validating the Green environment, you switch the traffic from Blue to Green.

Advantages:

  • Zero-downtime deployment.
  • Easy rollback by switching traffic back to the Blue environment.
  • Clear separation between old and new versions.

Canary Deployment:

Canary deployment involves gradually rolling out new versions to a small subset of users (called the “canary” group) to monitor for errors and performance issues. Over time, the traffic is shifted to the new version as confidence increases.

  • Canary Release: A small portion of the traffic is routed to the new version (e.g., 10% of users), while the rest continues using the old version.
  • Gradual Rollout: As the new version is tested, more traffic is routed to it, eventually reaching 100%.

Advantages:

  • Easier to implement than Blue/Green for incremental releases.
  • Can minimize risk by monitoring the early rollout and adjusting as needed.
  • Continuous integration and deployment (CI/CD) without full traffic switching.

Implementing Blue/Green Deployments in Kubernetes

In Kubernetes, Blue/Green deployments can be achieved using Deployments and Services. The idea is to manage two separate deployments (Blue and Green), and then switch the service to the Green deployment after it’s ready.

Steps for Blue/Green Deployment:

  1. Create Two Separate Deployments:
    • Define the Blue and Green deployments.
    • Both deployments will point to different versions of the application.
# Blue Deployment (Old version)
apiVersion: apps/v1
kind: Deployment
metadata:
  name: blue-deployment
spec:
  replicas: 3
  selector:
    matchLabels:
      app: my-app
      version: blue
  template:
    metadata:
      labels:
        app: my-app
        version: blue
    spec:
      containers:
        - name: my-app
          image: my-app:blue-version
          ports:
            - containerPort: 8080
# Green Deployment (New version)
apiVersion: apps/v1
kind: Deployment
metadata:
  name: green-deployment
spec:
  replicas: 3
  selector:
    matchLabels:
      app: my-app
      version: green
  template:
    metadata:
      labels:
        app: my-app
        version: green
    spec:
      containers:
        - name: my-app
          image: my-app:green-version
          ports:
            - containerPort: 8080
  1. Create a Service:
    • The service will initially point to the Blue deployment.
apiVersion: v1
kind: Service
metadata:
  name: my-app-service
spec:
  selector:
    app: my-app
    version: blue  # Initially points to Blue
  ports:
    - port: 80
      targetPort: 8080
  1. Switch Traffic to Green:
    • Once the Green deployment is verified and ready, switch the service selector to point to Green.
apiVersion: v1
kind: Service
metadata:
  name: my-app-service
spec:
  selector:
    app: my-app
    version: green  # Switch traffic to Green
  ports:
    - port: 80
      targetPort: 8080
  1. Rollback to Blue (if needed):
    • If issues occur with the Green deployment, switch the service back to the Blue version.
apiVersion: v1
kind: Service
metadata:
  name: my-app-service
spec:
  selector:
    app: my-app
    version: blue  # Rollback to Blue
  ports:
    - port: 80
      targetPort: 8080

Implementing Canary Deployments in Kubernetes

Canary deployments in Kubernetes typically use Deployments and Horizontal Pod Autoscaling (HPA) to gradually increase traffic to the new version.

Steps for Canary Deployment:

  1. Create the Primary (Stable) Deployment:
    • Define the stable version that will receive the majority of traffic.
apiVersion: apps/v1
kind: Deployment
metadata:
  name: stable-deployment
spec:
  replicas: 10
  selector:
    matchLabels:
      app: my-app
      version: stable
  template:
    metadata:
      labels:
        app: my-app
        version: stable
    spec:
      containers:
        - name: my-app
          image: my-app:stable-version
          ports:
            - containerPort: 8080
  1. Create the Canary Deployment:
    • Define a new deployment for the canary version with fewer replicas initially (e.g., 1-2 pods).
apiVersion: apps/v1
kind: Deployment
metadata:
  name: canary-deployment
spec:
  replicas: 2  # Small number of replicas for the canary release
  selector:
    matchLabels:
      app: my-app
      version: canary
  template:
    metadata:
      labels:
        app: my-app
        version: canary
    spec:
      containers:
        - name: my-app
          image: my-app:canary-version
          ports:
            - containerPort: 8080
  1. Create a Service:
    • Initially, the service routes traffic to the stable version, but as the canary deployment progresses, traffic is gradually shifted to the canary version.
apiVersion: v1
kind: Service
metadata:
  name: my-app-service
spec:
  selector:
    app: my-app
    version: stable  # Initially points to stable version
  ports:
    - port: 80
      targetPort: 8080
  1. Incrementally Shift Traffic to Canary:

    • Adjust the number of replicas for the canary deployment and the traffic distribution (using kubectl or CI/CD tools like Spinnaker).
    • Optionally, use a service mesh (e.g., Istio) or nginx-ingress to implement fine-grained traffic splitting.
  2. Gradual Traffic Split:

    • Use tools like NGINX Ingress or Istio to define the traffic split.
    • For instance, you can configure NGINX to route 10% of the traffic to the canary deployment and 90% to the stable version.

Example of traffic split with Istio (using VirtualService):

apiVersion: networking.istio.io/v1alpha3
kind: VirtualService
metadata:
  name: my-app
spec:
  hosts:
    - my-app.com
  http:
    - route:
        - destination:
            host: my-app-service
            subset: stable
          weight: 90
        - destination:
            host: my-app-service
            subset: canary
          weight: 10

Best Practices for Blue/Green and Canary Deployments

  • Testing and Monitoring: Always monitor application performance and user feedback during the deployment process. Integrate monitoring tools (e.g., Prometheus, Grafana) to track real-time metrics.
  • Rollback Strategy: Be prepared for a rollback plan. In Blue/Green, this is as simple as switching back to the Blue version. In Canary, adjust the traffic split and scale down the canary deployment if needed.
  • Automation: Use CI/CD pipelines (e.g., Jenkins, GitLab CI, Argo CD) to automate the deployment and rollback process. This ensures consistent and repeatable deployment strategies.
  • Use Readiness and Liveness Probes: Ensure that both Blue/Green and Canary deployments are monitored with Kubernetes readiness and liveness probes to guarantee that traffic is routed only to healthy pods.

Conclusion

Both Blue/Green and Canary deployments are essential strategies for minimizing the risk of downtime when deploying new versions of applications in Kubernetes. By using these strategies, you can ensure smoother rollouts and easier rollbacks, providing a reliable deployment pipeline for production environments.