Connect the target cluster to Zora¶
After preparing your target clusters, you need to connect them directly to Zora by following the instructions below.
Prerequisites¶
- A kubeconfig file with an authentication
token
of the target cluster. Follow these instructions to generate it. - The api-server of the target cluster must be reachable by the management cluster.
Without the prerequisites Zora will not be able to connect to the target cluster and will set a failure status.
Metrics Server
If the target cluster hasn't Metrics Server deployed, information about the usage of memory and CPU won't be collected and issues about potential resources over/under allocations won't be reported.
For more information about Metrics Server, visit the official documentation.
1. Access the management cluster¶
First, make sure you are in the context of the management cluster. You can do this by the following commands:
-
Display list of contexts:
kubectl config get-contexts
-
Display the current-context:
kubectl config current-context
-
Set the default context to my-management-cluster:
kubectl config use-context my-management-cluster
2. Create a Cluster
resource¶
First, create a Secret
with the content of the kubeconfig file:
kubectl create secret generic mycluster-kubeconfig \
-n zora-system \
--from-file=value=zora-view-kubeconfig.yml
Now, you are able to create a Cluster
resource referencing the kubeconfig Secret in the same namespace:
cat << EOF | kubectl apply -f -
apiVersion: zora.undistro.io/v1alpha1
kind: Cluster
metadata:
name: mycluster
namespace: zora-system
labels:
zora.undistro.io/environment: prod
spec:
kubeconfigRef:
name: mycluster-kubeconfig
EOF
If you've made it this far, congratulations, your clusters are connected.
Now you can list them and see the discovered data through kubectl
:
List clusters¶
kubectl get clusters -o wide
NAME VERSION MEM AVAILABLE MEM USAGE (%) CPU AVAILABLE CPU USAGE (%) NODES READY AGE PROVIDER REGION
mycluster v1.21.5-eks-bc4871b 10033Mi 3226Mi (32%) 5790m 647m (11%) 3 True 40d aws us-east-1
Tip
- Get clusters from all namespaces using
--all-namespaces
flag - Get clusters with additional information using
-o=wide
flag - Get the documentation for
clusters
manifests usingkubectl explain clusters
- Get cluster from
prod
environment usingkubectl get clusters -l zora.undistro.io/environment=prod
The cluster list output has the following columns:
NAME
: Cluster nameVERSION
: Kubernetes versionMEM AVAILABLE
: Quantity of memory available (requires Metrics Server)MEM USAGE (%)
: Usage of memory in quantity and percentage (requires Metrics Server)CPU AVAILABLE
: Quantity of CPU available (requires Metrics Server)CPU USAGE (%)
: Usage of CPU in quantity and percentage (requires Metrics Server)NODES
: Total of nodesREADY
: Indicates whether the cluster is connectedAGE
: Age of the kube-system namespace in clusterPROVIDER
: Cluster provider (with-o=wide
flag)REGION
: Cluster region (multi-region
if nodes have differenttopology.kubernetes.io/region
label) (with-o=wide
flag)
Provider
The value in PROVIDER
column is obtained by matching the Node's labels
(e.g., a Node with label key prefix eks.amazonaws.com/
means that the provider of this cluster is aws
).
For now, Zora recognizes only the providers in this list. But you can connect clusters of any provider. If the provider isn't in this list, the column will not be filled and Zora will continue to work normally.
Fell free to contribute to the project and add new labels prefixes for providers. See our contribution guidelines.
Info
- The quantity of available and in use resources, is a sum of all Nodes.
- Only one provider is displayed in
PROVIDER
column. Different information can be displayed for multi-cloud clusters. - Show detailed description of a cluster, including events, running
kubectl describe cluster mycluster
.