Open Cluster Management Deployment¶
Open Cluster Management installation is installed in two phases:
- Control Plane Deployment: it provides a control plane on top of a Kubernetes node or cluster to become the controller of the Open Cluster Management environment
- Managed Clusters Aggregation: it joins cluster/s to the previously installed control plane to start being orchestrated by the mentioned controller.
Control Plane Deployment¶
As part of Open Cluster Management Controller installation, the following prerequisites must be satisfied:
- Ensure kubectl and kustomize are installed.
-
The controller cluster should be Kubernetes v1.19+. (To run on controller cluster version between [v1.16, v1.18], please manually enable feature gate V1beta1CSRAPICompatibility).
-
Currently, the bootstrap process relies on client authentication via CSR. Therefore, Kubernetes distributions that don't support it can't be used as the controller.
For example: EKS.
To onboard OCM Controller it is necessary to install clusteradm client provided to correctly install all the components and dependencies required by the mentioned OCM.To do so, the described below command must be run:
curl -L https://raw.githubusercontent.com/open-cluster-management-io/clusteradm/main/install.sh | bash
For easing the installation process, the following environment variables should be declared:
# The context name of the clusters in your kubeconfig
export CTX_HUB_CLUSTER=<your hub cluster context>
Finally to trigger the installation process the below command must be executed:
# By default, it installs the latest release of the OCM components.
# NOTE: For hub cluster version between v1.16 to v1.19 use the parameter: --use-bootstrap-token
clusteradm init --wait --context ${CTX_HUB_CLUSTER}
kubectl -n open-cluster-management-hub get pod --context ${CTX_HUB_CLUSTER}
|NAME |READY|STATUS |RESTARTS|AGE |
|--------------------------------------------------------|-----|-------|--------|----|
|cluster-manager-placement-controller-857f8f7654-x7sfz | 1/1 |Running| 0 | 19d|
|cluster-manager-registration-controller-85b6bd784f-jbg8s| 1/1 |Running| 0 | 19d|
|cluster-manager-registration-webhook-59c9b89499-n7m2x | 1/1 |Running| 0 | 19d|
|cluster-manager-work-webhook-59cf7dc855-shq5p | 1/1 |Running| 0 | 19d|
|........................................................|.....|.......|........|....|
|........................................................|.....|.......|........|....|
Managed Cluster Aggregation:¶
As part of managed cluster aggregation process the following prerequisites must be satisfied:
- Ensure kubectl and kustomize are installed.
- The managed clusters should be v1.11+ .
To join a cluster to the OCM Controller it is necessary to install clusteradm client on that cluster as for the controller itself during the previous section. The steps are:
-
To Install clusteradm on the edge device
curl -L https://raw.githubusercontent.com/open-cluster-management-io/clusteradm/main/install.sh | bash
For easing the installation process, the following environment variables can be declared:
-
Ask to the ICOS support team a joining token for OCM.
-
Prepare to join the OCM Controller running on the ICOS Agent Finally, the following command must be executed on the cluster to become managed by OCM:
clusteradm join \ --hub-token <your token data> \ --hub-apiserver <your hub cluster endpoint> \ --wait \ --cluster-name "cluster1" \ # Or other arbitrary unique name --context ${CTX_MANAGED_CLUSTER}
For example:
To obtain a valid token the below shown command must be executed on the controller cluster: 4. Wait for the request to be accepted. Now your cluster has joined the ICOS Agent. After the join command is executed, the join request is sent, and it needs to be accepted from the OCM controller cluster. To do so the following steps must be followed:clusteradm join \ --hub-token <provided_token> \ --hub-apiserver https://10.160.3.240:6443 \ --wait \ --cluster-name "cluster1" \ # Or other arbitrary unique name
a. Wait for CSR object creation on the controller cluster:
kubectl get csr -w --context ${CTX_HUB_CLUSTER} | grep cluster1 # or the previously chosen cluster name #pending CSR request example: cluster1-tqcjj 33s kubernetes.io/kube-apiserver-client system:serviceaccount:open-cluster-management:cluster-bootstrap Pending
b. Accept the mentioned CSR request:
c. It should be verified that the agents are properly installed and running onto the managed cluster:
-
Verify that the agents are properly installed and running onto your cluster:
kubectl -n open-cluster-management-agent get pod |NAME |HUB ACCEPTED|MANAGED CLUSTER URLS|JOINED|AVAILABLE| AGE | |-----------|------------|--------------------|------|---------|------| |cluster1 |true |<your endpoint> |True | True | 5m23s|
The output should look something like this:
NAME READY STATUS klusterlet-registration-agent-598fd79988-jxx7n 1/1 Running klusterlet-work-agent-7d47f4b5c5-dnkqw 1/1 Running