Registering A New Cluster With ArgoCD

Michael Levan - Feb 28 '23 - - Dev Community

When you’re getting ready to utilize a GitOps Controller, whether it’s ArgoCD or another type, you’ll need a way to centralize what clusters you’re deploying to.

Afterall, chances are you aren’t only going to have one cluster in your entire organizations.

In this blog post, you’ll learn how to create the central location for ArgoCD so you can register multiple clusters to the same instance of ArgoCD.

Why

In many cases of any deployment method, you’ll want a central place to deploy from. For example, you don’t want to have multiple CICD systems to deploy from. You want one CICD system to deploy from.

The same thing goes for GitOps.

You could have ArgoCD installed on all clusters if you wanted to, but do you really want the headache of:

  1. Managing multiple instances of ArgoCD.
  2. Managing multiple passwords to log into various UIs.
  3. Managing the overall maintenance in the environment.

The answer is most likely no.

If the answer is no, you’ll want a Control Plane of sorts.

One ArgoCD instance running on a Kubernetes cluster that can connect to and deploy to your other Kubernetes clusters.

You can accomplish this by creating a Kubernetes cluster, installing ArgoCD, and then registering your other Kubernetes clusters to the ArgoCD instance.

The Architecture

The clusters are made up of the following:

  1. One AKS cluster
  2. One GKE cluster

You don’t have to have this combination. You could have an EKS cluster, two AKS clusters, two GKE clusters, or any other combination you’d like (including Managed Kubernetes Services that I didn’t mention).

ArgoCD is installed on the AKS cluster and acts as the Argo Control Plane. It then registers outside clusters (in this case, GKE), to deploy to.

Image description

The AKS Cluster (Argo Control Plane)

Before registering the GKE cluster, you’ll have to set up ArgoCD.

First, on the AKS cluster, create a new Namespace called argocd.



kubectl create namespace argocd


Enter fullscreen mode Exit fullscreen mode

Next, deploy ArgoCD to the Namespace.



kubectl apply -n argocd -f https://raw.githubusercontent.com/argoproj/argo-cd/stable/manifests/install.yaml


Enter fullscreen mode Exit fullscreen mode

Once deployed, you should be able to reach the ArgoCD service via port forwarding.



kubectl port-forward -n argocd service/argocd-server 67684:80


Enter fullscreen mode Exit fullscreen mode

Retrieve the ArgoCD password (it’s the default password that gets used and store in k8s secrets).



kubectl get secret -n argocd argocd-initial-admin-secret -o jsonpath="{.data.password}" | base64 -d


Enter fullscreen mode Exit fullscreen mode

Once you have the password and the ArgoCD service is up and running, you can log into the cluster via your terminal.



argocd login 127.0.0.1:argocd_port_here


Enter fullscreen mode Exit fullscreen mode

Image description

Registering A New Cluster

Once you’re logged into ArgoCD, the rest is straightofrward.

All you have to do is use the argocd cluster add command and for the flag and put in the name of the context for your GKE cluster.



argocd cluster add your_k8s_context_name


Enter fullscreen mode Exit fullscreen mode

You’ll see that a few resources get added on the target GKE cluster for ArgoCD to have the proper permissions to deploy Kubernetes Resources to the GKE cluster.

  • Service Account
  • Cluster Role
  • Cluster Role Binding

After that, the connection is made and you can now start deploying Kubernetes Resources to your GKE cluster from the ArgoCD server running in AKS.

Image description

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .