Argo Rollouts is a Kubernetes controller and set of CRDs which provide advanced deployment capabilities such as blue-green, canary, canary analysis, experimentation, and progressive delivery features to Kubernetes.
Argo Rollouts (optionally) integrates with ingress controllers and service meshes, leveraging their traffic shaping abilities to gradually shift traffic to the new version during an update. Additionally, Rollouts can query and interpret metrics from various providers to verify key KPIs and drive automated promotion or rollback during an update.
kubectl create namespace argo-rollouts
kubectl apply -n argo-rollouts -f https://github.com/argoproj/argo-rollouts/releases/latest/download/install.yaml
Follow the full getting started guide to walk through creating and then updating a rollout object.
Kubernetes Deployments provides the RollingUpdate
strategy which provide a basic set of safety guarantees (readiness probes) during an update. However the rolling update strategy faces many limitations:
- Few controls over the speed of the rollout
- Inability to control traffic flow to the new version
- Readiness probes are unsuitable for deeper, stress, or one-time checks
- No ability to query external metrics to verify an update
- Can halt the progression, but unable to automatically abort and rollback the update
For these reasons, in large scale high-volume production environments, a rolling update is often considered too risky of an update procedure since it provides no control over the blast radius, may rollout too aggressively, and provides no automated rollback upon failures.
- Blue-Green update strategy
- Canary update strategy
- Fine-grained, weighted traffic shifting
- Automated rollbacks and promotions
- Manual judgement
- Customizable metric queries and analysis of business KPIs
- Ingress controller integration: NGINX, ALB, Apache APISIX
- Service Mesh integration: Istio, Linkerd, SMI
- Metric provider integration: Prometheus, Wavefront, Kayenta, Web, Kubernetes Jobs, Datadog, New Relic, InfluxDB
Traffic Shaping Integration | SetWeight | SetWeightExperiments | SetMirror | SetHeader |
---|---|---|---|---|
ALB Ingress Controller | ✅ (stable) | ✅ (stable) | ❌ | ✅ (alpha) |
Ambassador | ✅ (stable) | ❌ | ❌ | ❌ |
Apache APISIX Ingress Controller | ✅ (alpha) | ❌ | ❌ | ✅ (alpha) |
Istio | ✅ (stable) | ✅ (stable) | ✅ (alpha) | ✅ (alpha) |
Nginx Ingress Controller | ✅ (stable) | ❌ | ❌ | ❌ |
SMI | ✅ (stable) | ✅ (stable) | ❌ | ❌ |
Traefik | ✅ (beta) | ❌ | ❌ | ❌ |
✅ = Supported
❌ = Not Supported
To learn more about Argo Rollouts go to the complete documentation.
You can reach the Argo Rollouts community and developers via the following channels:
- Q & A: Github Discussions
- Chat: The #argo-rollouts Slack channel
- Contributors Office Hours: Every Thursday | Agenda
- User Community meeting: First Wednesday of each month | Agenda
Official Argo Rollouts User List
- Awesome-Argo: A Curated List of Awesome Projects and Resources Related to Argo
- Automation of Everything - How To Combine Argo Events, Workflows & Pipelines, CD, and Rollouts
- Argo Rollouts - Canary Deployments Made Easy In Kubernetes
- How Intuit Does Canary and Blue Green Deployments
- Leveling Up Your CD: Unlocking Progressive Delivery on Kubernetes
- Minimize failed deployments with Argo Rollouts and Smoke tests
- Recover automatically from failed deployments with Argo Rollouts and Prometheus metrics
- Kubernetes Blue-Green deployments with Argo Rollouts
- Kubernetes canary deployments with Argo Rollouts
- GitOps with Argo CD and an Argo Rollouts canary release
- Multi-Stage Delivery with Keptn and Argo Rollouts
- Gradual Code Releases Using an In-House Kubernetes Canary Controller on top of Argo Rollouts
- How Scalable is Argo-Rollouts: A Cloud Operator’s Perspective
- Minimize Impact in Kubernetes Using Argo Rollouts
- Progressive Application Delivery with GitOps on Red Hat OpenShift