From 2b26d35b6df503a571592f64f49f1fc78a3cc948 Mon Sep 17 00:00:00 2001 From: Madhura Maskasky Date: Thu, 15 Dec 2022 10:50:49 -0800 Subject: [PATCH 01/18] Update concepts.md --- docs/concepts.md | 75 ++++++++++++++++++++++++++++++++++++++---------- 1 file changed, 60 insertions(+), 15 deletions(-) diff --git a/docs/concepts.md b/docs/concepts.md index e9374c20..48027da5 100644 --- a/docs/concepts.md +++ b/docs/concepts.md @@ -1,14 +1,20 @@ # Concepts +## Understanding the Fundamentals + +It is important to understand the fundamentals of the underlying technology that Arlon is built on, before you start making use of Arlon. +We recommend a good understanding of core concepts around [Docker](https://www.docker.com/), containerization, [Kubernetes](https://kubernetes.io/), GitOps and Continuous Delivery to understand the fundamentals behind Arlon. +We also recommend having a basic understanding of application templating technologies such as [Helm](https://helm.sh) and [Kustomize](https://kustomize.io) that are commonly used with Kubernetes. + ## Management cluster -This Kubernetes cluster hosts the following components: +Before you can use arlon, you need a Kubernetes cluster to host the following components: - ArgoCD - Arlon - Cluster management stacks e.g. Cluster API and/or Crossplane -The Arlon state and controllers reside in the arlon namespace. +The Arlon state and controllers reside in the arlon namespace on this cluster. ## Configuration bundle @@ -17,6 +23,15 @@ produce a set of Kubernetes manifests via a *tool*. This closely follows ArgoCD' definition of *tool types*. Consequently, the list of supported bundle types mirrors ArgoCD's supported set of manifest-producing tools. Each bundle is defined using a Kubernetes ConfigMap resource in the arlon namespace. +Additionally, a bundle can embed the data itself ("static bundle"), or contain a reference +to the data ("dynamic bundle"). A reference can be a URL, GitHub location, or Helm repo location. +The current list of supported bundle types is: + +- manifest_inline: a single manifest yaml file embedded in the resource +- manifest_ref: a reference to a single manifest yaml file +- dir_inline: an embedded tarball that expands to a directory of YAML files +- helm_inline: an embedded Helm chart package +- helm_ref: an external reference to a Helm chart ### Static bundle @@ -41,6 +56,18 @@ by ArgoCD, including plain YAML, Helm and Kustomize. When the user updates a dynamic bundle in git, all clusters consuming that bundle (through a profile specified at cluster creation time) will acquire the change. +### Bundle purpose + +Bundles can specify an optional *purpose* to help classify and organize them. +In the future, Arlon may order bundle installation by purpose order (for e.g. +install bundles with purpose=*networking* before others) but that is not the +case today. The currently *suggested* purpose values are: + +- networking +- add-on +- data-service +- application + ### Other properties A bundle can also have a comma-separated list of tags, and a description. @@ -51,6 +78,15 @@ Tags can be useful for classifying bundles, for e.g. by type A profile expresses a desired configuration for a Kubernetes cluster. It is just a set of references to bundles (static, dynamic, or a combination). +A profile is composed of: + +- An optional clusterspec. If specified, it allows the profile + to be used to create new clusters. + If absent, the profile can only be applied to existing clusters. +- A list of bundles specifying the configuration to apply onto the cluster + once it is operational +- An optional list of `values.yaml` settings for any Helm Chart type bundle + in the bundle list A profile can be static or dynamic. ### Static profile @@ -81,24 +117,33 @@ or acquire new bundles in real time. ## Cluster -An Arlon cluster, also known as workload cluster, is a Kubernetes cluster +An Arlon cluster, also called a 'workload cluster', is a Kubernetes cluster that Arlon creates and manages via a git directory structure stored in the workspace repository. -(Under construction) - -## Cluster spec +## Cluster Specification -A cluster spec contains desired settings when creating a new cluster. +The Cluster Specification, also called the 'Base Cluster' contains the desired settings when creating a new cluster. They currently include: -- API Provider: the cluster orchestration technology. Supported values are `CAPI` (Cluster API) and `xplane` (Crossplane) -- Cloud Provider: the infrastructure cloud provider. The currently supported values is `aws`, with `gcp` and `azure` support coming later. -- Type: the cluster type. Some API providers support more than one type. On `aws` cloud, Cluster API supports `kubeadm` and `eks`, whereas Crossplane only supports `eks`. -- The (worker) node instance type -- The initial (worker) node count -- The Kubernetes version +- A predefined list of Cluster API objects: Cluster, Machines, Machine Deployments, etc. to be deployed in the current namespace +- The specific infrastructure provider to be used (e.g aws) +- Kubernetes version +- Cluster nodepool type that need to be used for creating the cluster manifest (e.g eks, eks-managedmachinepool) + +To know more about 'Base Cluster', read about it [here](./baseclusters.md) + +## Cluster Chart + +The cluster chart is a Helm chart that creates (and optionally applies) the manifests necessary to create a cluster and deploy desired configurations and applications to it as a part of cluster creation, the following resources are created: The profile's Cluster Specification, bundle list and other settings are used to generate values for the cluster chart, and the chart is deployed as a Helm release into the *arlon* namespace in the management cluster. -## Base cluster +Here is a summary of the kinds of resources generated and deployed by the chart: -To know more about basecluster (Arlon gen2 clusters), read it [here](./baseclusters.md) +- A unique namespace with a name based on the cluster's name. All subsequent + resources below are created inside that namespace. +- The stack-specific resources to create the cluster (for e.g. Cluster API resources) +- A ClusterRegistration to automatically register the cluster with ArgoCD +- A GitRepoDir to automatically create a git repo and/or directory to host a copy + of the expanded bundles. Every bundle referenced by the profile is + copied/unpacked into its own subdirectory. +- One ArgoCD Application resource for each bundle. From 8bb3d85aa698b150840feb4cfecaae0ea7a68f1d Mon Sep 17 00:00:00 2001 From: Madhura Maskasky Date: Thu, 15 Dec 2022 12:44:08 -0800 Subject: [PATCH 02/18] Update concepts.md --- docs/concepts.md | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/docs/concepts.md b/docs/concepts.md index 48027da5..6204c5f4 100644 --- a/docs/concepts.md +++ b/docs/concepts.md @@ -123,7 +123,19 @@ the workspace repository. ## Cluster Specification -The Cluster Specification, also called the 'Base Cluster' contains the desired settings when creating a new cluster. +A cluster spec contains desired settings when creating a new cluster. +They currently include: + +- API Provider: the cluster orchestration technology. Supported values are `CAPI` (Cluster API) and `xplane` (Crossplane) +- Cloud Provider: the infrastructure cloud provider. The currently supported values is `aws`, with `gcp` and `azure` support coming later. +- Type: the cluster type. Some API providers support more than one type. On `aws` cloud, Cluster API supports `kubeadm` and `eks`, whereas Crossplane only supports `eks`. +- The (worker) node instance type +- The initial (worker) node count +- The Kubernetes version + +## Base Cluster + +The Base Cluster contains the desired settings when creating a new cluster. They currently include: - A predefined list of Cluster API objects: Cluster, Machines, Machine Deployments, etc. to be deployed in the current namespace From d8d361f5a2ab5de9d5eeee8e4fac6e2211f185c1 Mon Sep 17 00:00:00 2001 From: Madhura Maskasky Date: Thu, 15 Dec 2022 12:47:00 -0800 Subject: [PATCH 03/18] Delete design.md --- docs/design.md | 126 ------------------------------------------------- 1 file changed, 126 deletions(-) delete mode 100644 docs/design.md diff --git a/docs/design.md b/docs/design.md deleted file mode 100644 index a3810aa3..00000000 --- a/docs/design.md +++ /dev/null @@ -1,126 +0,0 @@ -# Arlon Design and Concepts - -## Management cluster - -This Kubernetes cluster hosts the following components: - -- ArgoCD -- Arlon -- Cluster management stacks e.g. Cluster API and/or Crossplane - -The Arlon state and controllers reside in the arlon namespace. - -## Configuration bundle - -A configuration bundle (or just "bundle") is grouping of data files that -produce a set of Kubernetes manifests via a *tool*. This closely follows ArgoCD's -definition of *tool types*. Consequently, the list of supported bundle -types mirrors ArgoCD's supported set of manifest-producing tools. -Each bundle is defined using a Kubernetes ConfigMap resource in the arlo namespace. -Additionally, a bundle can embed the data itself ("static bundle"), or contain a reference -to the data ("dynamic bundle"). A reference can be a URL, GitHub location, or Helm repo location. -The current list of supported bundle types is: - -- manifest_inline: a single manifest yaml file embedded in the resource -- manifest_ref: a reference to a single manifest yaml file -- dir_inline: an embedded tarball that expands to a directory of YAML files -- helm_inline: an embedded Helm chart package -- helm_ref: an external reference to a Helm chart - -### Bundle purpose - -Bundles can specify an optional *purpose* to help classify and organize them. -In the future, Arlon may order bundle installation by purpose order (for e.g. -install bundles with purpose=*networking* before others) but that is not the -case today. The currently *suggested* purpose values are: - -- networking -- add-on -- data-service -- application - -## Profile - -A profile expresses a desired configuration for a Kubernetes cluster. -It is composed of - -- An optional clusterspec. If specified, it allows the profile - to be used to create new clusters. - If absent, the profile can only be applied to existing clusters. -- A list of bundles specifying the configuration to apply onto the cluster - once it is operational -- An optional list of `values.yaml` settings for any Helm Chart type bundle - in the bundle list - -## Cluster - -### Cluster Specification/ Metadata - -A Cluster Specification contains desired settings when creating a new cluster. These settings are the values that define the shape and the configurations of the cluster. - -Currently, there is a difference in the cluster specification for gen1 and gen2 clusters. The main difference in these cluster specifications is that gen2 Cluster Specification allow users to deploy arbitrarily complex clusters using the full Cluster API feature set.This is also closer to the gitops and declarative style of cluster creation and gives users more control over the cluster that they deploy. - -#### gen1 - -A `clusterspec` contains desired settings when creating a new cluster. For gen1 clusters, this Cluster Specification is called [ClusterSpec](https://github.com/arlonproj/arlon/blob/main/docs/concepts.md#cluster-spec). - -Clusterspec currently includes: - -- Stack: the cluster provisioning stack, for e.g. *cluster-api* or *crossplane* -- Provider: the specific cluster management provider under that stack, - if applicable. Example: - for *cluster-api*, the possible values are *eks* and *kubeadm* -- Other settings that specify the "shape" of the cluster, such as the size of - the control plane and the initial number of nodes of the data plane. -- The pod networking technology (under discussion: this may be moved to a - bundle because most if not all CNI providers can be installed as manifests) - -#### gen2 - -for gen2 clusters, the Cluster Specification is called the base cluster, which is described in detail [here](https://github.com/arlonproj/arlon/blob/main/docs/baseclusters.md). - -A base cluster manifest consists of: - -- A predefined list of Cluster API objects: Cluster, Machines, Machine Deployments, etc. to be deployed in the current namespace -- The specific infrastructure provider to be used (e.g aws).ß -- Kubernetes version -- Cluster templates/ flavors that need to be used for creating the cluster manifest (e.g eks, eks-managedmachinepool) - -### Cluster Preparation - -Once these cluster specifications are created successfully, the next step is to prepare the cluster for deployment. - -#### gen1 - -Once the clusterspec is created for a gen-1 cluster, there is no need to prepare a workspace repository to create a new cluster. - -#### gen2 - -Once the base cluster manifest is created, the next step is to preare the workspace repository directory in which this base cluster manifest is present. This is explained in detail [here](https://github.com/arlonproj/arlon/blob/main/docs/baseclusters.md#preparation) - -### Cluster Creation - -Now, all the prerequisites for creating a cluster are completed and the cluster can be created/deployed. - -#### Cluster Chart - -The cluster chart is a Helm chart that creates (and optionally applies) the manifests necessary to create a cluster and deploy desired configurations and applications to it as a part of cluster creation, the following resources are created: The profile's Cluster Specification, bundle list and other settings are used to generate values for the cluster chart, and the chart is deployed as a Helm release into the *arlon* namespace in the management cluster. - -Here is a summary of the kinds of resources generated and deployed by the chart: - -- A unique namespace with a name based on the cluster's name. All subsequent - resources below are created inside that namespace. -- The stack-specific resources to create the cluster (for e.g. Cluster API resources) -- A ClusterRegistration to automatically register the cluster with ArgoCD -- A GitRepoDir to automatically create a git repo and/or directory to host a copy - of the expanded bundles. Every bundle referenced by the profile is - copied/unpacked into its own subdirectory. -- One ArgoCD Application resource for each bundle. - -#### gen1 - -Cluster deployment is explained [here](https://github.com/arlonproj/arlon/blob/main/docs/tutorial.md#clusters-gen1) - -#### gen2 - -Base cluster creation is explained [here](https://github.com/arlonproj/arlon/blob/main/docs/baseclusters.md#creation) From 007b858b3b233392195f5f97ea9a498de4d26ed5 Mon Sep 17 00:00:00 2001 From: Madhura Maskasky Date: Thu, 15 Dec 2022 13:06:19 -0800 Subject: [PATCH 04/18] Update mkdocs.yml --- mkdocs.yml | 1 - 1 file changed, 1 deletion(-) diff --git a/mkdocs.yml b/mkdocs.yml index 390db7de..f1163ebd 100644 --- a/mkdocs.yml +++ b/mkdocs.yml @@ -46,7 +46,6 @@ nav: - Overview: 'README.md' - Concepts: 'concepts.md' - Base clusters: 'baseclusters.md' - - Design: 'design.md' - Architecture: 'architecture.md' - Installation: 'installation.md' - Tutorial: 'gen2_Tutorial.md' From d0d647ea35b66dfd725bbf1da1214b22715273c7 Mon Sep 17 00:00:00 2001 From: Madhura Maskasky Date: Thu, 15 Dec 2022 13:15:47 -0800 Subject: [PATCH 05/18] Update concepts.md --- docs/concepts.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/docs/concepts.md b/docs/concepts.md index 6204c5f4..47c705cd 100644 --- a/docs/concepts.md +++ b/docs/concepts.md @@ -135,6 +135,8 @@ They currently include: ## Base Cluster +!!! NOTE: The 'Base Cluster' is a new and evolved way of specifying cluster configuration. It will become the default mechanism for specifying cluster configuration starting version 0.10.0 of Arlon + The Base Cluster contains the desired settings when creating a new cluster. They currently include: From 7d7fecb722c12b69184cb921e5ac32ad2084a1a0 Mon Sep 17 00:00:00 2001 From: Madhura Maskasky Date: Thu, 15 Dec 2022 13:17:06 -0800 Subject: [PATCH 06/18] Update concepts.md --- docs/concepts.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/concepts.md b/docs/concepts.md index 47c705cd..3bfa2ea1 100644 --- a/docs/concepts.md +++ b/docs/concepts.md @@ -135,7 +135,7 @@ They currently include: ## Base Cluster -!!! NOTE: The 'Base Cluster' is a new and evolved way of specifying cluster configuration. It will become the default mechanism for specifying cluster configuration starting version 0.10.0 of Arlon +!!! tip The 'Base Cluster' is a new and evolved way of specifying cluster configuration. It will become the default mechanism for specifying cluster configuration starting version 0.10.0 of Arlon The Base Cluster contains the desired settings when creating a new cluster. They currently include: From 36d7946f030aeea9ae82188ad908b62fe5627959 Mon Sep 17 00:00:00 2001 From: Madhura Maskasky Date: Thu, 15 Dec 2022 13:18:16 -0800 Subject: [PATCH 07/18] Update concepts.md --- docs/concepts.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/docs/concepts.md b/docs/concepts.md index 3bfa2ea1..d5ee0413 100644 --- a/docs/concepts.md +++ b/docs/concepts.md @@ -135,7 +135,8 @@ They currently include: ## Base Cluster -!!! tip The 'Base Cluster' is a new and evolved way of specifying cluster configuration. It will become the default mechanism for specifying cluster configuration starting version 0.10.0 of Arlon +!!! tip + The 'Base Cluster' is a new and evolved way of specifying cluster configuration. It will become the default mechanism for specifying cluster configuration starting version 0.10.0 of Arlon The Base Cluster contains the desired settings when creating a new cluster. They currently include: From 633e57d3cdc70864bbcbeb03d327c0c41cbc7bbe Mon Sep 17 00:00:00 2001 From: Madhura Maskasky Date: Thu, 15 Dec 2022 13:20:43 -0800 Subject: [PATCH 08/18] Update concepts.md --- docs/concepts.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/concepts.md b/docs/concepts.md index d5ee0413..9d614cfd 100644 --- a/docs/concepts.md +++ b/docs/concepts.md @@ -135,8 +135,8 @@ They currently include: ## Base Cluster -!!! tip - The 'Base Cluster' is a new and evolved way of specifying cluster configuration. It will become the default mechanism for specifying cluster configuration starting version 0.10.0 of Arlon +.. warning:: + The 'Base Cluster' is a new and evolved way of specifying cluster configuration. It will become the default mechanism for specifying cluster configuration starting version 0.10.0 of Arlon The Base Cluster contains the desired settings when creating a new cluster. They currently include: From 167c358b9929d09d77bb07a0b21c22dbe128ded2 Mon Sep 17 00:00:00 2001 From: Madhura Maskasky Date: Thu, 15 Dec 2022 13:21:31 -0800 Subject: [PATCH 09/18] Update concepts.md --- docs/concepts.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/concepts.md b/docs/concepts.md index 9d614cfd..5d9b6099 100644 --- a/docs/concepts.md +++ b/docs/concepts.md @@ -135,7 +135,7 @@ They currently include: ## Base Cluster -.. warning:: +!!! tip The 'Base Cluster' is a new and evolved way of specifying cluster configuration. It will become the default mechanism for specifying cluster configuration starting version 0.10.0 of Arlon The Base Cluster contains the desired settings when creating a new cluster. From 4d111a0c38158707b64542ed3f1bb621ea664d32 Mon Sep 17 00:00:00 2001 From: Madhura Maskasky Date: Thu, 15 Dec 2022 13:25:06 -0800 Subject: [PATCH 10/18] Update concepts.md --- docs/concepts.md | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/docs/concepts.md b/docs/concepts.md index 5d9b6099..3505d000 100644 --- a/docs/concepts.md +++ b/docs/concepts.md @@ -135,8 +135,7 @@ They currently include: ## Base Cluster -!!! tip - The 'Base Cluster' is a new and evolved way of specifying cluster configuration. It will become the default mechanism for specifying cluster configuration starting version 0.10.0 of Arlon +NOTE: The 'Base Cluster' is a new and evolved way of specifying cluster configuration. It will become the default mechanism for specifying cluster configuration starting version 0.10.0 of Arlon The Base Cluster contains the desired settings when creating a new cluster. They currently include: From d9c0a0e7dd0d376ce742d09f92e7f541fe5f1c98 Mon Sep 17 00:00:00 2001 From: Madhura Maskasky Date: Thu, 15 Dec 2022 13:29:00 -0800 Subject: [PATCH 11/18] Update architecture.md --- docs/architecture.md | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/docs/architecture.md b/docs/architecture.md index 666fee5e..285414da 100644 --- a/docs/architecture.md +++ b/docs/architecture.md @@ -7,7 +7,8 @@ functions as commands. In the future, an API server may be built from the library as well. Arlon adds CRDs (custom resource definitions) for several custom resources such as ClusterRegistration and Profile. -## Management cluster +## Components +### Management cluster The management cluster is a Kubernetes cluster hosting all the components needed by Arlon, including: @@ -22,7 +23,7 @@ needed by Arlon, including: The user is responsible for supplying the management cluster, and to have access to a kubeconfig granting administrator permissions on the cluster. -## Controller +### Controller The Arlon controller observes and responds to changes in `clusterregistration` custom resources. The Arlon library creates a `clusterregistration` at the @@ -31,7 +32,7 @@ causing the controller to wait for the cluster's kubeconfig to become available, at which point it registers the cluster with ArgoCD to enable manifests described by bundles to be deployed to the cluster. -## Library +### Library The Arlon library is a Go module that contains the functions that communicate with the Management Cluster to manipulate the Arlon state (bundles, profiles, clusterspecs) @@ -39,7 +40,7 @@ and transforms them into git directory structures to drive ArgoCD's gitops engin library is exposed via a CLI utility. In the future, it may also be embodied into a server an exposed via a network API. -## Workspace repository +### Workspace Repository As mentioned earlier, Arlon creates and maintains directory structures in a git repository to drive ArgoCD *sync* operations. @@ -51,7 +52,7 @@ register the workspace registry in ArgoCD before referencing it from Arlon data Starting from release v0.9.0, Arlon now includes two commands to help with managing various git repository URLs. With these commands in place, the `--repo-url` flag in commands requiring a hosted git repository is no longer needed. A more detailed explanation is given in the next [section](#repo-aliases). -### Repo Aliases +#### Repo Aliases A repo(repository) alias allows an Arlon user to register a GitHub repository with ArgoCD and store a local configuration file on their system that can be referenced by the CLI to then determine a repository URL and fetch its credentials when needed. All commands that require a repository, support a `--repo-url` flag also support a `repo-alias` flag to specify an alias instead of an alias, such commands will consider the "default" alias to be used when no `--repo-alias` and no `--repo-url` flags are given. @@ -83,11 +84,11 @@ The structure of the file is as shown: On running `arlon git unregister ALIAS`, it removes that entry from the configuration file. However, it does NOT remove the repository from `argocd`. When the "default" alias is deleted, we also clear the "default" entry from the JSON file. -#### Examples +##### Examples Given below are some examples for registering and unregistering a repository. -##### Registering Repositories +###### Registering Repositories Registering a repository requires the repository link, the GitHub username(`--user`), and a personal access token(`--password`). When the `--password` flag isn't provided at the command line, the CLI will prompt for a password(this is the recommended approach). @@ -105,7 +106,7 @@ arlon git register https://github.com/GhUser/manifests --user GhUser --password arlon git register https://github.com/GhUser/prod-manifests --user GhUser --alias prod --password $GH_PAT ``` -##### Unregistering Repositories +###### Unregistering Repositories Unregistering an alias only requires a positional argument: the repository alias. From c0348d71b8ee7c3477aae6d7822b2c824ad26fa7 Mon Sep 17 00:00:00 2001 From: Madhura Maskasky Date: Thu, 15 Dec 2022 16:25:24 -0800 Subject: [PATCH 12/18] Update installation.md --- docs/installation.md | 59 +++++++++++++++++++++++++++++--------------- 1 file changed, 39 insertions(+), 20 deletions(-) diff --git a/docs/installation.md b/docs/installation.md index f961c611..45f92391 100644 --- a/docs/installation.md +++ b/docs/installation.md @@ -1,21 +1,56 @@ # Installation +For a quickstart minimal demonstration setup, follow the instructions to set up a KIND based testbed with Arlon and ArgoCD running [here](https://github.com/arlonproj/arlon/blob/main/testing/README.md). + +Please follow the manual instructions in [this](#customised-setup) section for a customised setup or refer the instructions for automated installation [here](#automatic-setup). + +# Pre-requisites + +- A 'Management cluster'. You can use any Kubernetes cluster that you have admin access to. +- [kubectl](https://kubernetes.io/docs/tasks/tools/install-kubectl/) command line tool is installed and is in your path +- Have a valid [kubeconfig](https://kubernetes.io/docs/tasks/access-application-cluster/configure-access-multiple-clusters/) file (default location is `~/.kube/config`). +- `KUBECONFIG` environment variable is pointing to the right file and the context is set properly +- A hosted Git repository that will be used to store arlon artifacts, with at least a `README` file present. +- Pre-requisites for supported Cluster API infrastructure providers (AWS and Docker as of now). + +# Automatic Setup + +## 1. Download Arlon CLI + Arlon CLI downloads are provided on GitHub. The CLI is not a self-contained standalone executable though. It is required to point the CLI to a management cluster and set up the Arlon controller in this management cluster. -For a quickstart minimal demonstration setup, follow the instructions to set up a KIND based testbed with Arlon and ArgoCD running [here](https://github.com/arlonproj/arlon/blob/main/testing/README.md). +* Download the CLI for the [latest release](https://github.com/arlonproj/arlon/releases/latest) from GitHub. +Currently, Linux and MacOS operating systems are supported. +* Uncompress the tarball, rename it as `arlon` and add to your PATH +* Run `arlon verify` to check for prerequisites. +* Run `arlon install` to install any missing prerequisites. -Please follow the manual instructions in [this](#customised-setup) section for a customised setup or refer the instructions for automated installation [here](#automatic-setup). -# Customised Setup +## 2. Setup Arlon + +Arlon CLI provides an `init` command to install "itself" on a management cluster. +This command performs a basic setup of `argocd`(if needed) and `arlon` controller. +If `argocd` is already installed, it assumes that `admin` password is the same as in `argocd-initial-admin-secret` ConfigMap and that `argocd` resides in the `argocd` namespace. +Similar assumptions are made for detecting Arlon installation as well: assuming that the existence of `arlon` namespace means Arlon controller exists. + +* To start the installation process, run the following command +`arlon init -e --username --repoURL --password --examples -y`. +* This installs the controller, argocd(if not already present) +* `-e` flag adds basecluster manifests to the for using the given credentials. To not add examples, just remove the `-e` flag. +* The `-y` flag refers to silent installation, which is useful for scripts. For an interactive installation, exclude the `-y` or `--no-confirm` flag. + +# Customized Setup + +Use the customized setup if you would like to understand and potentially customize the different steps of the Arlon installation. For example, if you'd like to use Arlon with an existing instalation of ArgoCD. ## Management cluster You can use any Kubernetes cluster that you have admin access to. Ensure: - `kubectl` is in your path -- `KUBECONFIG` is pointing to the right file and the context set properly +- `KUBECONFIG` is pointing to the right file and the context is set properly ## ArgoCD @@ -115,19 +150,3 @@ cluster can noticeably slow down kubectl, and you may see a warning that looks l I0222 17:31:14.112689 27922 request.go:668] Waited for 1.046146023s due to client-side throttling, not priority and fairness, request: GET:https://AA61XXXXXXXXXXX.gr7.us-west-2.eks.amazonaws.com/apis/servicediscovery.aws.crossplane.io/v1alpha1?timeout=32s ``` -# Automatic Setup - -Arlon CLI provides an `init` command to install "itself" on a management cluster. -This command performs a basic setup of `argocd`(if needed) and `arlon` controller. -If `argocd` is already installed, it assumes that `admin` password is the same as in `argocd-initial-admin-secret` ConfigMap and that `argocd` resides in the `argocd` namespace. -Similar assumptions are made for detecting Arlon installation as well: assuming that the existence of `arlon` namespace means Arlon controller exists. -To install Arlon controller using the init command these pre-requisites need to be met: - -- A valid kubeconfig pointing to the management cluster. -- A hosted Git repository with at least a `README` file present. -- Pre-requisites for supported CAPI infrastructure providers(AWS and Docker as of now). - -To start the installation process, simply run `arlon init -e --username --repoURL --password --examples -y`. -This installs the controller, argocd(if not already present) `-e` flag adds basecluster manifests to the for using the given credentials. To not add examples, just remove the `-e` flag. -The `-y` flag refers to silent installation, which is useful for scripts. -For an interactive installation, exclude the `-y` or `--no-confirm` flag. From e856caaa31a18655698f03aefe5d1069c26fd8f8 Mon Sep 17 00:00:00 2001 From: Madhura Maskasky Date: Thu, 15 Dec 2022 16:30:41 -0800 Subject: [PATCH 13/18] Update installation.md --- docs/installation.md | 22 ++++++++-------------- 1 file changed, 8 insertions(+), 14 deletions(-) diff --git a/docs/installation.md b/docs/installation.md index 45f92391..5a54bf2b 100644 --- a/docs/installation.md +++ b/docs/installation.md @@ -45,14 +45,7 @@ Similar assumptions are made for detecting Arlon installation as well: assuming Use the customized setup if you would like to understand and potentially customize the different steps of the Arlon installation. For example, if you'd like to use Arlon with an existing instalation of ArgoCD. -## Management cluster - -You can use any Kubernetes cluster that you have admin access to. Ensure: - -- `kubectl` is in your path -- `KUBECONFIG` is pointing to the right file and the context is set properly - -## ArgoCD +## 1. Install ArgoCD - Follow steps 1-4 of the [ArgoCD installation guide](https://argo-cd.readthedocs.io/en/stable/getting_started/) to install ArgoCD onto your management cluster. After this step, you should be logged in as `admin` and a config file was created at `${HOME}/.config/argocd/config` @@ -86,7 +79,7 @@ kind: ConfigMap the previous step. Save changes. This file will be used to configure the Arlon controller's ArgoCD credentials during the next steps. -## Arlon controller +## 2. Install Arlon controller - Create the arlon namespace: `kubectl create ns arlon` - Create the ArgoCD credentials secret from the temporary config file: @@ -97,7 +90,7 @@ kind: ConfigMap - Deploy the controller: `kubectl apply -f deploy/manifests/` - Ensure the controller eventually enters the Running state: `watch kubectl -n arlon get pod` -## Arlon CLI +## 3. Install Arlon CLI Download the CLI for the [latest release](https://github.com/arlonproj/arlon/releases/latest) from GitHub. Currently, Linux and MacOS operating systems are supported. @@ -116,12 +109,13 @@ The following instructions are to manually build CLI from this code repository. (e.g. `/usr/local/bin`) included in your ${PATH} to the `bin/arlon` binary to make it easy to invoke the command. -## Cluster orchestration API providers +## 4. Install Cluster Orchestration API providers Arlon currently supports Cluster API on AWS cloud. It also has experimental -support for Crossplane on AWS. +support for Crossplane on AWS. +Install one of the following. -### Cluster API +### Install Cluster API Using the [Cluster API Quickstart Guide](https://cluster-api.sigs.k8s.io/user/quick-start.html) as reference, complete these steps: @@ -131,7 +125,7 @@ as reference, complete these steps: In particular, follow instructions for your specific cloud provider (AWS in this example) Ensure `clusterctl init` completes successfully and produces the expected output. -### Crossplane (experimental) +### Install Crossplane (experimental) Using the [Upbound AWS Reference Platform Quickstart Guide](https://github.com/upbound/platform-ref-aws#quick-start) as reference, complete these steps: From eb5682487f13e400ed16da75f1a9b1c82a84cf04 Mon Sep 17 00:00:00 2001 From: Madhura Maskasky Date: Thu, 15 Dec 2022 16:44:35 -0800 Subject: [PATCH 14/18] Update installation.md --- docs/installation.md | 1 + 1 file changed, 1 insertion(+) diff --git a/docs/installation.md b/docs/installation.md index 5a54bf2b..b420477e 100644 --- a/docs/installation.md +++ b/docs/installation.md @@ -7,6 +7,7 @@ Please follow the manual instructions in [this](#customised-setup) section for a # Pre-requisites +Make sure that you have: - A 'Management cluster'. You can use any Kubernetes cluster that you have admin access to. - [kubectl](https://kubernetes.io/docs/tasks/tools/install-kubectl/) command line tool is installed and is in your path - Have a valid [kubeconfig](https://kubernetes.io/docs/tasks/access-application-cluster/configure-access-multiple-clusters/) file (default location is `~/.kube/config`). From bf37343095fde3abf2811408e0e5a8e6f09b41f2 Mon Sep 17 00:00:00 2001 From: Madhura Maskasky Date: Thu, 15 Dec 2022 16:49:07 -0800 Subject: [PATCH 15/18] Update concepts.md --- docs/concepts.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/docs/concepts.md b/docs/concepts.md index 3505d000..dd6d8d73 100644 --- a/docs/concepts.md +++ b/docs/concepts.md @@ -137,8 +137,10 @@ They currently include: NOTE: The 'Base Cluster' is a new and evolved way of specifying cluster configuration. It will become the default mechanism for specifying cluster configuration starting version 0.10.0 of Arlon -The Base Cluster contains the desired settings when creating a new cluster. -They currently include: +A Base Cluster allows you to create workload clusters from a manifest file stored in a git repository. The manifest +typically contains multiple related resources that together define an arbitrarily complex cluster. +If you make subsequent changes to the Base Cluster manifest, workload clusters originally created from it will automatically acquire the changes. +The Base Cluster defines: - A predefined list of Cluster API objects: Cluster, Machines, Machine Deployments, etc. to be deployed in the current namespace - The specific infrastructure provider to be used (e.g aws) From 0e8600db6e229a7491a65f087209ca9d6059a2fd Mon Sep 17 00:00:00 2001 From: Madhura Maskasky Date: Thu, 15 Dec 2022 16:58:10 -0800 Subject: [PATCH 16/18] Update gen2_Tutorial.md --- docs/gen2_Tutorial.md | 55 ++++++++++++++++++------------------------- 1 file changed, 23 insertions(+), 32 deletions(-) diff --git a/docs/gen2_Tutorial.md b/docs/gen2_Tutorial.md index a5d76716..99c67905 100644 --- a/docs/gen2_Tutorial.md +++ b/docs/gen2_Tutorial.md @@ -1,28 +1,19 @@ -# Next-Generation (gen2) Clusters - New in version 0.9.x +# Tutorial -Gen1 clusters are limited in capability by the Helm chart used to deploy the infrastructure resources. -Advanced Cluster API configurations, such as those using multiple MachinePools, each with different -instance types, is not supported. +The following tutorial provides steps to create an AWS EKS cluster using Arlon. Once created, the cluster will be automatically monitored for changes by Arlon. Any changes to the cluster will be auto-corrected to conform to the manifest specifided in git. Any updates to the manifest in git will automatically be applied to the cluster. -Gen2 clusters solve this problem by allowing you to create workload clusters from a *base cluster* -that you design and provide in the form of a manifest file stored in a git directory. The manifest -typically contains multiple related resources that together define an arbitrarily complex cluster. -If you make subsequent changes to the base cluster, workload clusters originally created from it -will automatically acquire the changes. +**NOTE - Base Clusters only support dynamic profiles.** -**NB: Base clusters only support dynamic profiles.** +## Pre-requisites -## Creating Cluster-API cluster manifest +* The Cluster API AWS Provider (CAPA) version used here is v2.0 and the manifests created here are in accordance with this version. Refer to the [compatibility matrix for Cluster API provider and CAPA versions](https://github.com/kubernetes-sigs/cluster-api-provider-aws#compatibility-with-cluster-api-and-kubernetes-versions) for supported versions. +* Setup the AWS Environment as stated in the [quickstart giude for CAPI](https://cluster-api.sigs.k8s.io/user/quick-start.html) -Note: The CAPA version used here is v2.0 and the manifests created here are in accordance with this version. +## 1. Create Cluster-API Cluster Manifest -Refer the [compatibility matrix for Cluster API provider and CAPA versions](https://github.com/kubernetes-sigs/cluster-api-provider-aws#compatibility-with-cluster-api-and-kubernetes-versions) for supported versions. +### Create Manifest for EKS MachineDeployment -Before deploying a EKS cluster, make sure to setup the AWS Environment as stated in the [quickstart giude for CAPI](https://cluster-api.sigs.k8s.io/user/quick-start.html) - -### MachineDeployment - -Here is an example of a manifest file that we can use to create a *base cluster*. This manifest file helps in +Here is an example of a manifest file that we can use to create a *Base Cluster*. This manifest file helps in deploying an EKS cluster with 'machine deployment' component from the cluster API (CAPI). This file has been generated by the following command ```shell @@ -115,11 +106,11 @@ spec: template: {} ``` -### AWSManagedMachinePool +### Create Manifest for EKS AWSManagedMachinePool -Initialize the environment for AWSManagedMachinePool as stated [here](https://cluster-api-aws.sigs.k8s.io/topics/machinepools.html#awsmanagedmachinepool) +* Initialize the environment for AWSManagedMachinePool as stated [here](https://cluster-api-aws.sigs.k8s.io/topics/machinepools.html#awsmanagedmachinepool) -Before deploying an EKS cluster, make sure that the MachinePool feature gate is enabled. To do so, run this command: +* Before deploying an EKS cluster, make sure that the MachinePool feature gate is enabled. To do so, run this command: ```shell kubectl describe deployment capa-controller-manager -n capa-system @@ -137,7 +128,7 @@ AutoControllerIdentityCreator=true,BootstrapFormatIgnition=false,ExternalResourc .......... ``` -This manifest file helps in deploying an EKS cluster with 'AWSManagedMachinePool' component from the cluster API (CAPI). This file has been generated by the following command +* The manifest file below helps in deploying an EKS cluster with 'AWSManagedMachinePool' component from the cluster API (CAPI). This file has been generated by the following command ```shell clusterctl generate cluster awsmanaged-cluster --kubernetes-version v1.22.0 --flavor eks-managedmachinepool > manifest.yaml @@ -207,13 +198,13 @@ metadata: spec: {} ``` -### AWSMachinePool +### Create Manifest for EKS AWSMachinePool An AWSMachinePool corresponds to an AWS AutoScaling Groups, which provides the cloud provider specific resource for orchestrating a group of EC2 machines. -Initialize the environment for AWSMachinePool as stated [here]() +* Initialize the environment for AWSMachinePool as stated [here]() -Before deploying an EKS cluster, make sure that the AWSMachinePool feature gate is enabled. To do so, run this command: +* Before deploying an EKS cluster, make sure that the AWSMachinePool feature gate is enabled. To do so, run this command: ```shell kubectl describe deployment capa-controller-manager -n capa-system @@ -231,7 +222,7 @@ AutoControllerIdentityCreator=true,BootstrapFormatIgnition=false,ExternalResourc .......... ``` -This manifest file helps in deploying an EKS cluster with 'AWSManagedMachinePool' component from the cluster API (CAPI). This file has been generated by the following command +* The below manifest file helps in deploying an EKS cluster with 'AWSManagedMachinePool' component from the cluster API (CAPI). This file has been generated by the following command ```shell clusterctl generate cluster awsmanaged-cluster --kubernetes-version v1.22.0 --flavor eks-machinepool > manifest.yaml @@ -318,7 +309,7 @@ metadata: spec: {} ``` -## gen2 cluster creation using Arlon +### Create Cluster using Arlon This manifest file needs to be pushed to the workspace repository before the manifest directory is prepped and then validated. @@ -326,7 +317,7 @@ Before a manifest directory can be used as a base cluster, it must first be "pre by Arlon. The "prep" phase makes minor changes to the directory and manifest to help Arlon deploy multiple copies of the cluster without naming conflicts. -## manifest directory preparation +#### Prepare the manifest directory To prepare a git directory to serve as base cluster, use the `basecluster preparegit` command: @@ -340,7 +331,7 @@ arlon basecluster preparegit --repo-path [--repo-revision revi arlon basecluster preparegit --repo-alias prod --repo-path [--repo-revision revision] ``` -## manifest directory validation +#### Validate the manifest directory Post the successful preparation of the basecluster manifest directory using `basecluster preparegit`, the basecluster manifest directory needs to be validated before the basecluster is created. @@ -356,7 +347,7 @@ arlon basecluster validategit --repo-path [--repo-revision rev arlon basecluster validategit --repo-alias prod --repo-path [--repo-revision revision] ``` -## gen2 cluster creation +#### Create cluster To create a gen2 workload cluster from the base cluster: @@ -370,7 +361,7 @@ arlon cluster create --cluster-name --repo-path arlon cluster create --cluster-name --repo-alias prod --repo-path [--output-yaml] [--profile ] [--repo-revision ] ``` -## gen2 cluster update +#### Update Cluster To update the profiles of a gen2 workload cluster: @@ -387,7 +378,7 @@ to the existing cluster which will create profile app in argocd along with bundl An existing profile can be deleted from the cluster as well using the above command. Executing this command will delete the profile app and all the bundles associated with the profile in argocd. -## gen2 cluster deletion +#### Delete Cluster To destroy a gen2 workload cluster: From 0aa23236cf706168d75932b137557f73b04f009a Mon Sep 17 00:00:00 2001 From: Madhura Maskasky Date: Thu, 15 Dec 2022 17:00:18 -0800 Subject: [PATCH 17/18] Update gen2_Tutorial.md --- docs/gen2_Tutorial.md | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/docs/gen2_Tutorial.md b/docs/gen2_Tutorial.md index 99c67905..e0ca482f 100644 --- a/docs/gen2_Tutorial.md +++ b/docs/gen2_Tutorial.md @@ -309,7 +309,7 @@ metadata: spec: {} ``` -### Create Cluster using Arlon +## 2. Create Cluster using Arlon This manifest file needs to be pushed to the workspace repository before the manifest directory is prepped and then validated. @@ -317,7 +317,7 @@ Before a manifest directory can be used as a base cluster, it must first be "pre by Arlon. The "prep" phase makes minor changes to the directory and manifest to help Arlon deploy multiple copies of the cluster without naming conflicts. -#### Prepare the manifest directory +### Prepare the Manifest Directory To prepare a git directory to serve as base cluster, use the `basecluster preparegit` command: @@ -331,7 +331,7 @@ arlon basecluster preparegit --repo-path [--repo-revision revi arlon basecluster preparegit --repo-alias prod --repo-path [--repo-revision revision] ``` -#### Validate the manifest directory +### Validate the Manifest Directory Post the successful preparation of the basecluster manifest directory using `basecluster preparegit`, the basecluster manifest directory needs to be validated before the basecluster is created. @@ -347,7 +347,7 @@ arlon basecluster validategit --repo-path [--repo-revision rev arlon basecluster validategit --repo-alias prod --repo-path [--repo-revision revision] ``` -#### Create cluster +### Create Cluster To create a gen2 workload cluster from the base cluster: @@ -361,7 +361,7 @@ arlon cluster create --cluster-name --repo-path arlon cluster create --cluster-name --repo-alias prod --repo-path [--output-yaml] [--profile ] [--repo-revision ] ``` -#### Update Cluster +## Update Cluster To update the profiles of a gen2 workload cluster: @@ -378,7 +378,7 @@ to the existing cluster which will create profile app in argocd along with bundl An existing profile can be deleted from the cluster as well using the above command. Executing this command will delete the profile app and all the bundles associated with the profile in argocd. -#### Delete Cluster +## Delete Cluster To destroy a gen2 workload cluster: From efbe4d2be1e228133079c6b8a2ace9337968807c Mon Sep 17 00:00:00 2001 From: Madhura Maskasky Date: Thu, 15 Dec 2022 17:01:08 -0800 Subject: [PATCH 18/18] Update gen2_Tutorial.md --- docs/gen2_Tutorial.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/gen2_Tutorial.md b/docs/gen2_Tutorial.md index e0ca482f..965e3798 100644 --- a/docs/gen2_Tutorial.md +++ b/docs/gen2_Tutorial.md @@ -361,7 +361,7 @@ arlon cluster create --cluster-name --repo-path arlon cluster create --cluster-name --repo-alias prod --repo-path [--output-yaml] [--profile ] [--repo-revision ] ``` -## Update Cluster +## 3. Update Cluster To update the profiles of a gen2 workload cluster: @@ -378,7 +378,7 @@ to the existing cluster which will create profile app in argocd along with bundl An existing profile can be deleted from the cluster as well using the above command. Executing this command will delete the profile app and all the bundles associated with the profile in argocd. -## Delete Cluster +## 4. Delete Cluster To destroy a gen2 workload cluster: