Skip to content

Commit

Permalink
Add working vSphere template
Browse files Browse the repository at this point in the history
Signed-off-by: Alexandr Demicev <[email protected]>
  • Loading branch information
alexander-demicev committed Aug 2, 2024
1 parent b226680 commit 974d7c4
Show file tree
Hide file tree
Showing 9 changed files with 395 additions and 366 deletions.
64 changes: 34 additions & 30 deletions samples/vmware/README.md
Original file line number Diff line number Diff line change
@@ -1,39 +1,43 @@
# Example manifests

This config includes a kubevip loadbalancer on the controlplane nodes. The VIP of the loadbalancer for the Kubernetes API is set by the CABPR_CONTROLPLANE_ENDPOINT variable.
This config includes a kubevip loadbalancer on the controlplane nodes. The VIP of the loadbalancer for the Kubernetes API is set by the CONTROL_PLANE_ENDPOINT_IP.

Usage:
Prerequisites:

export environmental variables below
- VM template to be used for the cluster machine should be present in the vSphere environment.
- If airgapped environment is required then the VM template should already include RKE2 binaries as described in the [docs](https://docs.rke2.io/install/airgap#tarball-method). CAPRKE2 is using the tarball method to install RKE2 on the machines.
Any additional images like vSphere CPI image should be present in the local environment too.

```
export CABPR_NAMESPACE=example
export CABPR_CLUSTER_NAME=rke2
export CABPR_CP_REPLICAS=3
export CABPR_WK_REPLICAS=2
export KUBERNETES_VERSION=v1.24.6
export RKE2_VERSION=v1.24.6+rke2r1
export CABPR_CONTROLPLANE_ENDPOINT=192.168.1.100
export CABPR_VCENTER_HOSTNAME=vcenter.example.com
export CABPR_VCENTER_USERNAME=admin
export CABPR_VCENTER_PASSWORD=password
export CABPR_VCENTER_DATACENTER=datacenter
export CABPR_VCENTER_NETWORK=vmnetwork
export CABPR_VCENTER_THUMBPRINT=
export CABPR_VCENTER_DATASTORE=datastore
export CABPR_VCENTER_DISKSIZE=25
export CABPR_VCENTER_FOLDER=vm-folder
export CABPR_VCENTER_RESOURCEPOOL="*/Resources/resoucrepool"
export CABPR_VCENTER_VM_VPCU=2
export CABPR_VCENTER_VM_MEMORY=4096
export CABPR_VCENTER_VM_TEMPLATE=template
To initialize Cluster API Provider vSphere, clusterctl requires the following variables, which should be set in ~/.cluster-api/clusterctl.yaml as the following:

```bash
## -- Controller settings -- ##
VSPHERE_USERNAME: "<username>" # The username used to access the remote vSphere endpoint
VSPHERE_PASSWORD: "<password>" # The password used to access the remote vSphere endpoint

## -- Required workload cluster default settings -- ##
VSPHERE_SERVER: "10.0.0.1" # The vCenter server IP or FQDN
VSPHERE_DATACENTER: "SDDC-Datacenter" # The vSphere datacenter to deploy the management cluster on
VSPHERE_DATASTORE: "DefaultDatastore" # The vSphere datastore to deploy the management cluster on
VSPHERE_NETWORK: "VM Network" # The VM network to deploy the management cluster on
VSPHERE_RESOURCE_POOL: "*/Resources" # The vSphere resource pool for your VMs
VSPHERE_FOLDER: "vm" # The VM folder for your VMs. Set to "" to use the root vSphere folder
VSPHERE_TEMPLATE: "ubuntu-1804-kube-v1.17.3" # The VM template to use for your management cluster.
CONTROL_PLANE_ENDPOINT_IP: "192.168.9.230" # the IP that kube-vip is going to use as a control plane endpoint
VSPHERE_TLS_THUMBPRINT: "..." # sha256 thumbprint of the vcenter certificate: openssl x509 -sha256 -fingerprint -in ca.crt -noout
EXP_CLUSTER_RESOURCE_SET: "true" # This enables the ClusterResourceSet feature that we are using to deploy CSI
VSPHERE_SSH_AUTHORIZED_KEY: "ssh-rsa AAAAB3N..." # The public ssh authorized key on all machines in this cluster.
# Set to "" if you don't want to enable SSH, or are using another solution.
"CPI_IMAGE_K8S_VERSION": "v1.30.0" # The version of the vSphere CPI image to be used by the CPI workloads
# Keep this close to the minimum Kubernetes version of the cluster being created.
```

Create the namespace first.
Then run the following command to generate the RKE2 cluster manifests:

```bash
clusterctl generate cluster --from https://github.com/rancher/cluster-api-provider-rke2/blob/main/samples/vmware/cluster-template.yaml -n example-vsphere rke2-vsphere > vsphere-rke2-clusterctl.yaml
```

run:
```shell
envsubt < namespace.yaml | kubectl apply -f -
envsubt < *.yaml | kubectl apply -f -
```bash
kubectl apply -f vsphere-rke2-clusterctl.yaml
```
Loading

0 comments on commit 974d7c4

Please sign in to comment.