Chapter 2. Enabling the Argo CD plugin
You can use the Argo CD plugin to visualize the Continuous Delivery (CD) workflows in OpenShift GitOps. This plugin provides a visual overview of the status of the application, deployment details, commit message, author of the commit, container image promoted to environment and deployment history.
Prerequisites
Add Argo CD instance information to your
app-config.yaml
configmap as shown in the following example:Copy to Clipboard Copied! Toggle word wrap Toggle overflow NoteAvoid using a trailing slash in the
url
, as it might cause unexpected behavior.Add the following annotation to the entity
catalog-info.yaml
file to identify the Argo CD applications.annotations: ... # The label that Argo CD uses to fetch all the applications. The format to be used is label.key=label.value. For example, rht-gitops.com/janus-argocd=quarkus-app. argocd/app-selector: '${ARGOCD_LABEL_SELECTOR}'
annotations: ... # The label that Argo CD uses to fetch all the applications. The format to be used is label.key=label.value. For example, rht-gitops.com/janus-argocd=quarkus-app. argocd/app-selector: '${ARGOCD_LABEL_SELECTOR}'
Copy to Clipboard Copied! Toggle word wrap Toggle overflow (Optional) Add the following annotation to the entity’s
catalog-info.yaml
file to switch between Argo CD instances as shown in the following example:annotations: ... # The Argo CD instance name used in `app-config.yaml`. argocd/instance-name: '${ARGOCD_INSTANCE}'
annotations: ... # The Argo CD instance name used in `app-config.yaml`. argocd/instance-name: '${ARGOCD_INSTANCE}'
Copy to Clipboard Copied! Toggle word wrap Toggle overflow NoteIf you do not set this annotation, the Argo CD plugin defaults to the first Argo CD instance configured in
app-config.yaml
.
Procedure
Add the following to your dynamic-plugins ConfigMap to enable the Argo CD plugin.
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
2.1. Enabling Argo CD Rollouts Copy linkLink copied to clipboard!
The optional Argo CD Rollouts feature enhances Kubernetes by providing advanced deployment strategies, such as blue-green and canary deployments, for your applications. When integrated into the backstage Kubernetes plugin, it allows developers and operations teams to visualize and manage Argo CD Rollouts seamlessly within the Backstage interface.
Prerequisites
The Backstage Kubernetes plugin (
@backstage/plugin-kubernetes
) is installed and configured.- To install and configure Kubernetes plugin in Backstage, see Installaltion and Configuration guide.
-
You have access to the Kubernetes cluster with the necessary permissions to create and manage custom resources and
ClusterRoles
. -
The Kubernetes cluster has the
argoproj.io
group resources (for example, Rollouts and AnalysisRuns) installed.
Procedure
In the
app-config.yaml
file in your Backstage instance, add the followingcustomResources
component under thekubernetes
configuration to enable Argo Rollouts and AnalysisRuns:Copy to Clipboard Copied! Toggle word wrap Toggle overflow Grant
ClusterRole
permissions for custom resources.Note-
If the Backstage Kubernetes plugin is already configured, the
ClusterRole
permissions for Rollouts and AnalysisRuns might already be granted. -
Use the prepared manifest to provide read-only
ClusterRole
access to both the Kubernetes and ArgoCD plugins.
-
If the
ClusterRole
permission is not granted, use the following YAML manifest to create theClusterRole
:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Apply the manifest to the cluster using
kubectl
:kubectl apply -f <your-clusterrole-file>.yaml
kubectl apply -f <your-clusterrole-file>.yaml
Copy to Clipboard Copied! Toggle word wrap Toggle overflow -
Ensure the
ServiceAccount
accessing the cluster has thisClusterRole
assigned.
-
If the Backstage Kubernetes plugin is already configured, the
Add annotations to
catalog-info.yaml
to identify Kubernetes resources for Backstage.For identifying resources by entity ID:
annotations: ... backstage.io/kubernetes-id: <BACKSTAGE_ENTITY_NAME>
annotations: ... backstage.io/kubernetes-id: <BACKSTAGE_ENTITY_NAME>
Copy to Clipboard Copied! Toggle word wrap Toggle overflow (Optional) For identifying resources by namespace:
annotations: ... backstage.io/kubernetes-namespace: <RESOURCE_NAMESPACE>
annotations: ... backstage.io/kubernetes-namespace: <RESOURCE_NAMESPACE>
Copy to Clipboard Copied! Toggle word wrap Toggle overflow For using custom label selectors, which override resource identification by entity ID or namespace:
annotations: ... backstage.io/kubernetes-label-selector: 'app=my-app,component=front-end'
annotations: ... backstage.io/kubernetes-label-selector: 'app=my-app,component=front-end'
Copy to Clipboard Copied! Toggle word wrap Toggle overflow NoteEnsure you specify the labels declared in
backstage.io/kubernetes-label-selector
on your Kubernetes resources. This annotation overrides entity-based or namespace-based identification annotations, such asbackstage.io/kubernetes-id
andbackstage.io/kubernetes-namespace
.
Add label to Kubernetes resources to enable Backstage to find the appropriate Kubernetes resources.
Backstage Kubernetes plugin label: Add this label to map resources to specific Backstage entities.
labels: ... backstage.io/kubernetes-id: <BACKSTAGE_ENTITY_NAME>
labels: ... backstage.io/kubernetes-id: <BACKSTAGE_ENTITY_NAME>
Copy to Clipboard Copied! Toggle word wrap Toggle overflow GitOps application mapping: Add this label to map Argo CD Rollouts to a specific GitOps application
labels: ... app.kubernetes.io/instance: <GITOPS_APPLICATION_NAME>
labels: ... app.kubernetes.io/instance: <GITOPS_APPLICATION_NAME>
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
NoteIf using the label selector annotation (backstage.io/kubernetes-label-selector), ensure the specified labels are present on the resources. The label selector will override other annotations like kubernetes-id or kubernetes-namespace.
Verification
- Push the updated configuration to your GitOps repository to trigger a rollout.
- Open Red Hat Developer Hub interface and navigate to the entity you configured.
- Select the CD tab and then select the GitOps application. The side panel opens.
In the Resources table of the side panel, verify that the following resources are displayed:
- Rollouts
- AnalysisRuns (optional)
Expand a rollout resource and review the following details:
- The Revisions row displays traffic distribution details for different rollout versions.
- The Analysis Runs row displays the status of analysis tasks that evaluate rollout success.