From 5c0eb786ef5f459b96ec041e1e880f964df0aab2 Mon Sep 17 00:00:00 2001 From: Phantom-Intruder Date: Sat, 22 Jul 2023 11:49:05 +0530 Subject: [PATCH 1/3] ArgoCD EKS started --- GitOps101/argocd-eks.md | 42 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 GitOps101/argocd-eks.md diff --git a/GitOps101/argocd-eks.md b/GitOps101/argocd-eks.md new file mode 100644 index 00000000..976627dc --- /dev/null +++ b/GitOps101/argocd-eks.md @@ -0,0 +1,42 @@ +# Deploying ArgoCD with AWS EKS + +For the demonstration of this lab, let us now perform continuous deployment with ArgoCD for an EKS cluster with a GitHub repo. + +## Requirements + +You need a GitHub repo that has some sample code in it, an EKS cluster (performance and the number of nodes do not matter), and [ArgoCD CLI](https://argo-cd.readthedocs.io/en/stable/cli_installation/) installed. + +To start, make sure that your kubeconfig is pointing to the correct Kubernetes cluster, and let's start by creating a namespace for argocd: + +``` +kubectl create ns argocd +``` + +Followed by the ArgoCD deployment: + +``` +kubectl apply -n argocd -f https://raw.githubusercontent.com/argoproj/argo-cd/stable/manifests/install.yaml +``` + +This is the same set of commands run in the previous general ArgoCD setup lab and would install several Kubernetes resources into your cluster. + +Ensure that all the pods are running properly: + +``` +kubectl get po -n argocd +kubectl get svc -n argocd +``` + +You will see that there is a service that runs for ArgoCD. However, this service is only accessible from within the cluster. We will be using ALBs to make the location generally available in the future but for now, let's use port forwarding to access the dashboard. + +``` +kubectl port-forward svc/argocd-server -n argocd 8080:443 +``` + +You can now access the ArgoCD dashboard via localhost:8080. The initial username is admin, and the initial password can be found by running: + +``` +kubectl -n argocd get secret argocd-initial-admin-secret -o jsonpath="{.data.password}" +``` + +Note that this is a base64 value, and therefore needs to be decoded to get the actual password. You should then be good to log in to ArgoCD. \ No newline at end of file From 4efe55961c4053e67238b4ea66ac195e3667fd58 Mon Sep 17 00:00:00 2001 From: Phantom-Intruder Date: Sun, 23 Jul 2023 12:03:51 +0530 Subject: [PATCH 2/3] ArgoCD EKS completed --- GitOps101/argocd-eks.md | 42 +++++++++++++++++++++++++++++++++++++++-- 1 file changed, 40 insertions(+), 2 deletions(-) diff --git a/GitOps101/argocd-eks.md b/GitOps101/argocd-eks.md index 976627dc..c110a62e 100644 --- a/GitOps101/argocd-eks.md +++ b/GitOps101/argocd-eks.md @@ -4,7 +4,7 @@ For the demonstration of this lab, let us now perform continuous deployment with ## Requirements -You need a GitHub repo that has some sample code in it, an EKS cluster (performance and the number of nodes do not matter), and [ArgoCD CLI](https://argo-cd.readthedocs.io/en/stable/cli_installation/) installed. +You need a GitHub repo that has some sample code in it (optional since ArgoCD provides a sample), an EKS cluster (performance and the number of nodes do not matter), and [ArgoCD CLI](https://argo-cd.readthedocs.io/en/stable/cli_installation/) installed. To start, make sure that your kubeconfig is pointing to the correct Kubernetes cluster, and let's start by creating a namespace for argocd: @@ -39,4 +39,42 @@ You can now access the ArgoCD dashboard via localhost:8080. The initial username kubectl -n argocd get secret argocd-initial-admin-secret -o jsonpath="{.data.password}" ``` -Note that this is a base64 value, and therefore needs to be decoded to get the actual password. You should then be good to log in to ArgoCD. \ No newline at end of file +Note that this is a base64 value, and therefore needs to be decoded to get the actual password. You should then be good to log in to ArgoCD. + +You can play around with the ArgoCD dashboard a bit, but we will get into that later. For now, open up a new terminal instance, and type: + +``` +argocd login localhost:8080 +``` + +Now, you will need to provide the login credentials in the same way that you did with the dashboard. With that, you would have logged in to ArgoCD from the CLI. This is important since the ArgoCD docs mostly provide you with information on how to use Argo via CLI with CLI commands. To start, we will be setting up a project using the sample ArgoCD [helm-guestbook](https://github.com/argoproj/argocd-example-apps/tree/master/helm-guestbook): + +``` +argocd app create helm-guestbook --repo https://github.com/argoproj/argocd-example-apps.git --path helm-guestbook --dest-server https://kubernetes.default.svc --dest-namespace default +``` + +The above command creates a project called `helm-guestbook` from the `argocd-example-apps` repo. In the `path` argument, you specify which folder within the repo has the files ArgoCD needs to be concerned with. This is useful for a large project that has application code residing alongside the CI/CD code. Once the command is run, the repo will show up in ArgoCD, but a connection will not be made. You can use: + +``` +argocd app get helm-guestbook +``` + +You will see that the repo is out of sync. To get it to sync, use: + +``` +argocd app sync helm-guestbook +``` + +This will take a couple of minutes, but once it is complete, you should see that the application is in sync and healthy. Note that all this wasn't just a visual input. Rather, the application actually synchronized the Helm chart provided in the `helm-guestbook` folder and deployed it to your Kubernetes cluster. If you were to run: + +``` +kubectl get pods +``` + +you would see that a pod by the name of `helm-guestbook` is not running. In fact, you can access this application by first port forwarding: + +``` +kubectl port-forward svc/helm-guestbook 9090:80 +``` + +And then go to http://localhost:9090. \ No newline at end of file From ecc769eb1dde0e4975c8e218c8adde8571c173a5 Mon Sep 17 00:00:00 2001 From: Phantom-Intruder Date: Wed, 26 Jul 2023 08:07:33 +0530 Subject: [PATCH 3/3] ArgoCD eks complete --- GitOps101/argocd-eks.md | 8 +++++++- README.md | 1 + 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/GitOps101/argocd-eks.md b/GitOps101/argocd-eks.md index c110a62e..e2fb933d 100644 --- a/GitOps101/argocd-eks.md +++ b/GitOps101/argocd-eks.md @@ -77,4 +77,10 @@ you would see that a pod by the name of `helm-guestbook` is not running. In fact kubectl port-forward svc/helm-guestbook 9090:80 ``` -And then go to http://localhost:9090. \ No newline at end of file +And then go to http://localhost:9090. You should see a web application. + +And that's it! Notice you didn't deploy any files yourself. You didn't add the repo with Helm, or install it. In fact, you didn't even clone the repo. All this was handled by ArgoCD. If there is a push to the repo, ArgoCD will automatically deploy the change to your cluster without any intervention from you. + +## Conclusion + +In this lab, we have seen how you can use ArgoCD to automate deployments to your EKS cluster with no intervention from yourself. This is roughly the same method you use when using ArgoCD with other cloud Kubernetes engines, as well as self-managed Kubernetes clusters. \ No newline at end of file diff --git a/README.md b/README.md index 2f1a6fee..d05214b6 100644 --- a/README.md +++ b/README.md @@ -235,6 +235,7 @@ ## GitOps101 - [What is GitOps](./GitOps101/what-is-gitops.md) - [ArgoCD](./GitOps101/argocd.md) +- [ArgoCD with EKS](./GitOps101/argocd-eks.md) ## Managed Kubernetes Service - [Managed Kubernetes Service Intro](./ManagedKubernetes/readme.md)