Custom Images
This document will help you get a CAPC Kubernetes cluster up and running with your custom image.
Prebuilt Images
An image defines the operating system and Kubernetes components that will populate the disk of each node in your cluster.
As of now, prebuilt images for KVM, VMware and XenServer are available here
Building a custom image
Cluster API uses the Kubernetes Image Builder tools. You should use the CloudStack images from that project as a starting point for your custom image.
The Image Builder Book explains how to build the images defined in that repository, with instructions for CloudStack CAPI Images in particular.
The image is built using KVM hypervisor as a qcow2
image.
Following which, it is then converted into ova
for VMware and vhd
for XenServer as a post-processors
build step.
Depending on the requirement and the hypervisor, the post-processors
can be modified.
If you build Apache CloudStack CAPI images with the make
targets in Image Builder, these required values are printed after a successful build. For example:
$ make -C images/capi/ build-cloudstack-ubuntu-2004
# many minutes later...
==> qemu:
Build 'qemu' finished after 45 minutes 54 seconds.
11:13:48 ==> Builds finished. The artifacts of successful builds are:
11:13:48 --> qemu: VM files in directory: ./output/ubuntu-2004-kube-v1.21.10
11:13:48 --> qemu: VM files in directory: ./output/ubuntu-2004-kube-v1.21.10
11:13:48 --> qemu: VM files in directory: ./output/ubuntu-2004-kube-v1.21.10
Operating system requirements
For your custom image to work with Cluster API, it must meet the operating system requirements of the bootstrap provider. For example, the default kubeadm
bootstrap provider has a set of preflight checks
that a VM is expected to pass before it can join the cluster.
Kubernetes version requirements
The reference images are each built to support a specific version of Kubernetes. When using your custom images based on them, take care to match the image to the version:
field of the KubeadmControlPlane
and MachineDeployment
in the YAML template for your workload cluster.
Creating a cluster from a custom image
To use a custom image, it needs to be referenced in an image:
section of your CloudStackMachineTemplate
.
Be sure to also update the version
in the KubeadmControlPlane
and MachineDeployment
cluster spec.
apiVersion: infrastructure.cluster.x-k8s.io/v1beta1
kind: CloudStackMachineTemplate
metadata:
name: capi-quickstart-control-plane
spec:
template:
spec:
offering: ControlPlaneOffering
template: custom-image-name
Upgrading Kubernetes Versions
To upgrade to a new Kubernetes release with custom images requires this preparation:
- Create a new custom image which supports the Kubernetes release version
- Register the custom image as a template in Apache CloudStack
- Copy the existing
CloudStackMachineTemplate
and change itsimage:
section to reference the new custom image - Create the new
CloudStackMachineTemplate
on the management cluster - Modify the existing
KubeadmControlPlane
andMachineDeployment
to reference the newCloudStackMachineTemplate
and update theversion:
field to match
See Upgrading workload clusters for more details.