ArlonCTL Tutorial
In this Tutorial, we will deploy an EKS cluster consisting of two worker nodes using Arlon, by making use of ArlonCTL.
For context around what is Arlon, PMK integration with Arlon, and ArlonCTL, please first read Profile Engine with Arlon and ArlonCTL
Download
Download arlonctl on your machine using this command:
bash <(curl -sL https://arlon-assets.s3.us-west-1.amazonaws.com/arlonCTL/5.6/arlonctl_setup)This downloads arlonctl in /usr/local/bin/arlonctl
Currently, the supported OS are :
- Linux(amd64)
- MacOs(amd64, arm64)
Verify
Check if all the prerequisite tools are installed and running by running : arlonctl verify
To run arlonctl commands, kubectl is a required tool and git, argocd CLI are optional requirements. In order to download these tools, do refer to these links below:
- kubectl: http://pwittrock.github.io/docs/tasks/tools/install-kubectl/
- argocd: https://argo-cd.readthedocs.io/en/stable/cli_installation/
- git: https://git-scm.com/book/en/v2/Getting-Started-Installing-Git
Context Creation
This command allows user to create and switch between two or more DUs / contexts. It makes it easy and efficient for the user to manage multiple DUs.
The first step is to create a context for the current DU.This can be done by running:
arlonctl context create <context-name>This command creates a new context, which the user can then work with. The current context will be set to the newly created context using this command. To create a new context, the user needs to add their DU-FQDN, their username and password.
After the context creation is successful, it can be verified by using arlonctl context list which shows the current context being used.
All the contexts which have been added by the user are stored in a contexts.json file which is at ~/.config/arlon. Sensitive credentials such as passwords are stored in the JSON file after being encrypted. The kubeconfig of the current DU as well is stored in the same location with the name context.config. The logs for all the arlonctl commands are stored in ~/.config/arlon/logs.txt
Workspace Repo
If the verification is successful and all the required tools are installed, go ahead and add a workspace repository to argocd. This git repo is the “source of truth” for all the apps. This is the repo, where arlonctl will add all the files and manifests related to the profiles, bundles, clusters To add a repo to argocd, use this command :
argocd repo add $WORKSPACE_REPO_URL --username $User --password $GITHUB_PAT$GITHUB_PAT is the Github Personal Access Token.
$User is the github username.
$WORKSPACE_REPO_URL is the github url of the workspace repo.
Cloud Provider
Once the repo has been added to argocd, proceed to add a cloudprovider(AWS) in PMK UI. After the cloudprovider is successfully added to the DU, list the cloud providers present in the DU using arlonctl.
> arlonctl cloudprovider list  NAME CLOUDPROVIDER  aws f59538340-awsCreating Cluster Components
Bundle
A bundle is a grouping of data files that produce a set of Kubernetes manifests via a tool.Each bundle is defined using a Kubernetes secret in the arlon namespace.
Static Bundle: A static bundle embeds the manifest's YAML data itself and is not affected by subsequent changes to this manifest.
Download xenial.yaml from : https://github.com/arlonproj/arlon/blob/main/examples/bundles/xenial.yaml. We will create a static bundle using this app.
arlonctl bundle create xenial --tags application --desc "sample app" --from-file xenial.yamlDynamic Bundle: A dynamic bundle contains a reference to the manifest data stored in git.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.
We will create a dynamic version of the same application, this time using a reference to a git directory containing the YAML.Clone the git repository that was earlier added to ArgoCD. Then follow these steps :
cd ${WORKSPACE_REPO}mkdir -p bundles/xenialcp xenial.yaml bundles/xenialgit add bundles/xenialgit commit -m "add xenial bundle"git push origin mainOnce this bundle is added to your workspace repository, proceed to create a dynamic bundle.
$WORKSPACE_REPO_URL is the workspace repo url that has earlier been added to ArgoCD.
Profile
A profile expresses a desired configuration for a Kubernetes cluster. It's a collection of bundles (static, dynamic, or a combination). A profile can be static or dynamic. Profiles are stored in git as YAMLs.
Static Profile: When a cluster consumes a static profile at creation time, the set of bundles for the cluster is fixed at that time and does not change over time even when the static bundle is updated.
arlonctl profile create prof-1 --bundles xenial --desc "static profile 1" --tags examplesDynamic Profile: Any change in the bundles present in the profile will get reflected in the dynamic profile. Any cluster consuming that dynamic profile will be affected by the change, meaning it may lose or acquire new bundles in real time.
    arlonctl profile create xenial-dynamic --repo-url ${WORKSPACE_REPO_URL} --repo-base-path profiles --bundles xenial-dynamic --desc "dynamic profile(xenial app)" --tags examples$WORKSPACE_REPO_URL is the workspace repo url that has earlier been added to ArgoCD.
Clusterspec
It is the specification that describes the characteristics (size and shape) of the cluster to be deployed. i.e. the API (CAPI/ Crossplane), the cloud, version of Kubernetes, number of nodes in the cluster etc.
    arlonctl clusterspec create eks-1 --api capi --cloud aws --type eks --kubeversion v1.23.7 --nodecount 2 --nodetype $NODETYPE --tags staging --desc "2 node eks for general purpose" --DUcloudProvider $CLOUD_PROVIDER --region $AWS_REGION --sshkey $SSH_KEY$CLOUD_PROVIDER is the output of arlonctl cloudprovider list.
$AWS_REGION is the AWS Region.
$SSH_KEY is the AWS SSH Key.
$NODETYPE is the size of the node (e.g. t2.large, t2.medium).
Cluster
It is a Kubernetes cluster that pf9-arlon creates and manages via a git directory structure stored in the workspace repository.
Cluster: arlonctl-1 (Static Profile and Static Bundle):
arlonctl cluster deploy --repo-url $WORKSPACE_REPO_URL --profile prof-1 --cluster-name arlonctl-1 --cluster-spec eks-1Cluster: arlonctl-2 (Dynamic Profile and Dynamic Bundle):
    arlonctl cluster deploy --repo-url $WORKSPACE_REPO_URL --profile xenial-dynamic --cluster-name arlonctl-2 --cluster-spec eks-1$WORKSPACE_REPO_URL is the workspace repo url that has earlier been added to ArgoCD.
Once the cluster is deployed, the status of the apps and the cluster deployed by Arlon can be queries by running the following command from the ArgoCD CLI :
argocd app list