Two types of installation:
- install.yaml - Standard installation method.
kubectl create namespace argo-rollouts kubectl apply -n argo-rollouts -f https://github.com/argoproj/argo-rollouts/releases/latest/download/install.yaml
This will create a new namespace,
argo-rollouts, where Argo Rollouts controller will run.
If you are using another namespace name, please update
install.yaml clusterrolebinding's serviceaccount namespace name.
When installing Argo Rollouts on Kubernetes v1.14 or lower, the CRD manifests must be kubectl applied with the --validate=false option. This is caused by use of new CRD fields introduced in v1.15, which are rejected by default in lower API servers.
On GKE, you will need grant your account the ability to create new cluster roles:
kubectl create clusterrolebinding YOURNAME-cluster-admin-binding --clusterrole=cluster-admin --user=YOUREMAIL@gmail.com
- namespace-install.yaml - Installation of Argo Rollouts which requires only namespace level privileges. An example usage of this installation method would be to run several Argo Rollouts controller instances in different namespaces on the same cluster.
Note: Argo Rollouts CRDs are not included into namespace-install.yaml. and have to be installed separately. The CRD manifests are located in manifests/crds directory. Use the following command to install them:
kubectl apply -k https://github.com/argoproj/argo-rollouts/manifests/crds\?ref\=stable
You can find released container images of the controller at Quay.io. There are also old releases at Dockerhub, but since the introduction of rate limiting, the Argo project has moved to Quay.
Kubectl Plugin Installation¶
The kubectl plugin is optional, but is convenient for managing and visualizing rollouts from the command line.
brew install argoproj/tap/kubectl-argo-rollouts
Install Argo Rollouts Kubectl plugin with curl.
curl -LO https://github.com/argoproj/argo-rollouts/releases/latest/download/kubectl-argo-rollouts-darwin-amd64
For Linux dist, replace
Make the kubectl-argo-rollouts binary executable.
chmod +x ./kubectl-argo-rollouts-darwin-amd64
Move the binary into your PATH.
sudo mv ./kubectl-argo-rollouts-darwin-amd64 /usr/local/bin/kubectl-argo-rollouts
Test to ensure the version you installed is up-to-date:
kubectl argo rollouts version
Shell auto completion¶
The CLI can export shell completion code for several shells.
For bash, ensure you have bash completions installed and enabled. To access completions in your current shell, run $
source <(kubectl-argo-rollouts completion bash). Alternatively, write it to a file and source in
The completion command supports bash, zsh, fish and powershell.
See the completion command documentation for more details.
Using the CLI with Docker¶
The CLI is also available as a container image at https://quay.io/repository/argoproj/kubectl-argo-rollouts
You can run it like any other Docker image or use it in any CI platform that supports Docker images.
docker run quay.io/argoproj/kubectl-argo-rollouts:master version
At any point in time the officially supported version of Argo Rollouts is the latest released one, on Kubernetes versions N and N-1 (as supported by the Kubernetes project itself).
For example if the latest minor version of Argo Rollouts is 1.2.1 and supported Kubernetes versions are 1.24, 1.23 and 1.22 then the following combinations are supported:
- Argo Rollouts 1.2.1 on Kubernetes 1.24
- Argo Rollouts 1.2.1 on Kubernetes 1.23
Upgrading Argo Rollouts¶
Argo Rollouts is a Kubernetes controller that doesn't hold any external state. It is active only when deployments are actually happening.
To upgrade Argo Rollouts:
- Try to find a time period when no deployments are happening
- Delete the previous version of the controller and apply/install the new one
- When a new Rollout takes place the new controller will be activated.
If deployments are happening while you upgrade the controller, then you shouldn't have any downtime. Current Rollouts will be paused and as soon as the new controller becomes active it will resume all in-flight deployments.