VCF on VCD: Replace Hosts in Stretched Cluster
From one of my customers, I got a question on how they can downsize a stretched cluster in a VCF environment. This is basically following the first 5 steps in the “Replace a Failed Host in a Stretched Cluster” article: https://docs.vmware.com/en/VMware-Cloud-Foundation/5.0/vcf-admin/GUID-92FD3AEE-5B5F-421C-B722-44AE0314D84E.html
So I though, I’d try it out.
We need to do the following steps:
- Get Host ID’s
- Get Cluster ID
- Prepare JSON file
- Run JSON file
- Decommission hosts
So, first, we get the Host ID’s. For this we go to the “Developer Center” in the SDDC Manager and click on: API Explorer.
data:image/s3,"s3://crabby-images/a93a8/a93a840d3ec2ca3aae8936b9e0586ec5d3c4aa55" alt=""
There we find the “Hosts” Categorie and Execute “Get”
data:image/s3,"s3://crabby-images/1d074/1d07409238274c72963de1a9fbd7117b4195cca9" alt=""
We get a list of Hosts, and we can find the ones we need. In my case, I want to remove esx52 (because I have an issue with the local datastore) and to make things equal, I will also remove esx42:
data:image/s3,"s3://crabby-images/0418d/0418deccb26c6a8f07abdf603d7b161c551a1593" alt=""
From here we make a note of the “id”: (string) value. In these cases:
- “7178ffd0-08e2-4b23-a5ae-177f00942a03”
- “687d54c0-c166-449c-aa5f-bfc1c9a118d2”
Next, we will go looking for the Cluster ID. For this we find the Category Cluster, and Execute the “List” command:
data:image/s3,"s3://crabby-images/80ec9/80ec943bc56eb009250a7926a2552ad617911b98" alt=""
and get the Cluster ID for the cluster we are going to perform the activity on:
data:image/s3,"s3://crabby-images/58e8a/58e8aab6e81b9e0519635f871937e326fbbd4376" alt=""
So, the Cluster ID is: “83b5d49f-eea3-4b89-bb31-742c52076712”.
With this information, we go and create the correct JSON file:
data:image/s3,"s3://crabby-images/f1693/f16934b53aa398dfaddf1b54b5a71c0c1d13f493" alt=""
With this JSON, we go to the Category Clusters and find “Patch/v1/clusters/id and fill out the right information. The Cluster id as well as the content of the created JSON:
data:image/s3,"s3://crabby-images/009cb/009cb2a95d5ef6515d4c2ae5f5cb694f71aa38f6" alt=""
and click on Execute. First, we get a confirmation and when we accept this, we will see a Task appearing in the Tasks list:
data:image/s3,"s3://crabby-images/27b6b/27b6b3dbb8124af1962ae99d70e8a2c3a17983ca" alt=""
data:image/s3,"s3://crabby-images/b2ee1/b2ee1a363656a19d91c8e3dd4d4c11fc032c5075" alt=""
data:image/s3,"s3://crabby-images/cae83/cae83a4fa99f5b98d096b62de5537f19348227b4" alt=""
and the subtasks:
data:image/s3,"s3://crabby-images/7d158/7d158b6d52da0269b2ce1ec8f0b4bdee4a31b400" alt=""
The hosts are placed in Maintenance Mode and removed:
data:image/s3,"s3://crabby-images/0f057/0f057b74ac6645bf53507b106d42ff53d5ccf080" alt=""
When all is done, the cluster is down two hosts and we see that there are two hosts that are available for Decommission in SDDC Manager:
data:image/s3,"s3://crabby-images/504a4/504a4fa90105f122b11346afa6e3742d7a81f8b5" alt=""
data:image/s3,"s3://crabby-images/de8c0/de8c0ed7fa83720f6fada19d65a1084e64a3e2fe" alt=""
So we will Decommission them, clean them up, reinstall them, and then, part 2, add them to the cluster again.
data:image/s3,"s3://crabby-images/44e81/44e8127c42675c80ac652ea3178e0fd5451cdd3d" alt=""
After the reinstallation, we commission the hosts (see earlier posts on this) and after that, we go back to API Explorer.
The next steps follow the procedure described in: https://docs.vmware.com/en/VMware-Cloud-Foundation/5.0/vcf-admin/GUID-928542C0-65E1-46F1-A62D-E7A106AC593B.html#GUID-928542C0-65E1-46F1-A62D-E7A106AC593B
So, Part 2, adding hosts to a stretched cluster. For this, we follow the following steps:
- (Commission Hosts, this has already been done)
- Find the ID’s for the hosts (same way as in the first phase)
- Find the ID for the cluster (same way as in the first phase)
- Find the names for the Availability Zones
- Create JSON
- Execute JSON
The first 3 steps have been performed and give us:
Hosts:
- “a7a83ab2-c8fa-475f-b8b5-ca25003b80d5” – esx42 (AZ1)
- “d2531110-00a7-4fc1-89f5-bba928b2028b” – esx52 (AZ2)
Cluster:
- “83b5d49f-eea3-4b89-bb31-742c52076712”
The AZ Names, we find in vCenter:
data:image/s3,"s3://crabby-images/8aad0/8aad0985ba2ebff2b3803bead7aaa25825e320b8" alt=""
So:
- WLD02-CL01_primary-az-faultdomain (AZ1)
- WLD02-CL01_secondary-az-faultdomain (AZ2)
With this information, we can create our JSON:
data:image/s3,"s3://crabby-images/7c19f/7c19f90a8282e7b87aacb68f0150559b0e954c12" alt=""
and run the JSON as part of the “Patch /v1/clusters/id”:
data:image/s3,"s3://crabby-images/26662/2666220954288219188fefdba25b227a3bc04200" alt=""
Which creates the task:
data:image/s3,"s3://crabby-images/59aa0/59aa088733ef4246aa3766596739e7c6e09ae2a8" alt=""
data:image/s3,"s3://crabby-images/e8f90/e8f909792b7e0e494f28aa6306644a22e83fbffc" alt=""
And it’s subtasks:
data:image/s3,"s3://crabby-images/ce695/ce695623020f6db7b6536bf922a1bdad4a5372f0" alt=""
And after this has been completed, we have two new shiny hosts, added to our stretched cluster:
data:image/s3,"s3://crabby-images/06857/068572b3202d7e0c2499a1191209d2aeca9af89b" alt=""
(be it with some warnings, but those will be solved).