This repo contains shell scripts that create resources within the target cluster that will used to generate a kubeconfig.yml that can be shared with the Kloudle team.
The script adds the following Kubernetes resources
- ClusterRole - kloudle-cluster-reader
- ClusterRoleBinding - kloudle-global-cluster-reader
- Service Account - kloudle-cluster-admin-readonly
- Service Account Secret Token - kloudle-cluster-admin-readonly-secret-token
Repo contains two primary scripts
- A shell script to create readonly resources for a cluster that is reachable over the Internet - kubernetes-readonly-admin-creator.sh
- A shell script that sets up a Tinyproxy HTTP/HTTPS proxy and then creates readonly resources for a cluster that is internal and not reachable over the Internet - kubernetes-jumpbox-proxy-readonly-admin-setup.sh
- A kubernetes administrator or user with the ability to create resources at cluster level, is required to run the shell script as it invokes kubectl with the user credentials.
- Also ensure your kubeconfig cluster context is set correctly, else the script will create resources in the current context. You can verify this using kubectl cluster-info.
Depending on whether your cluster is internal or external (private or reachable over the Internet), you can choose the following
You can pass the shell script to cURL directly using the raw GitHub URL. The script creates ReadOnly resources in the target cluster.
curl -sS https://raw.githubusercontent.com/Kloudle/kloudle-kubernetes-onboarding/refs/heads/master/kubernetes-readonly-admin-creator.sh | bashA file called kloudle-cluster-admin-readonly-TIMESTAMP.yml will be created in a folder called k8s-kloudle-onboarding-kubeconfigs. For example - kloudle-cluster-admin-readonly-29-04-2024-18-49-38.yml
Upload this file to the Kloudle App via the Kubernetes Onboarding page.
This script is meant to be run on a jumpbox/bastion host (basically a machine that can reach the cluster). The script does the following
- installs Tinyproxyand sets up a HTTP/HTTPS proxy on the jumpbox
- creates ReadOnly resources in the target cluster
Note: The jumpbox needs to be alive even after the script is created for Kloudle to reach the internal cluster and perform its scans.
curl -sS https://raw.githubusercontent.com/Kloudle/kloudle-kubernetes-onboarding/refs/heads/master/kubernetes-jumpbox-proxy-readonly-admin-setup.sh | bashA file called kloudle-cluster-admin-readonly-TIMESTAMP.yml will be created in a folder called k8s-kloudle-onboarding-kubeconfigs. For example - kloudle-cluster-admin-readonly-29-04-2024-18-49-38.yml
Upload this file to the Kloudle App via the Kubernetes Onboarding page.