Cluster API
The Cluster API (AKA CAPI) is a project from the Cluster Lifecycle SIG. Its goal is to make provisioning, upgrading, and operating multiple Kubernetes clusters easy. It supports both kubeadm-based clusters as well as managed clusters via dedicated providers. It has a cool logo inspired by the famous “It’s turtles all the way down” story. The idea is that the Cluster API uses Kubernetes to manage Kubernetes clusters.
data:image/s3,"s3://crabby-images/b0c3c/b0c3cf7f027a566303e483c4c0379b74d0ea95ce" alt=""
Figure 11.1: The Cluster API logo
Cluster API architecture
The Cluster API has a very clean and extensible architecture. The primary components are:
- The management cluster
- The work cluster
- The bootstrap provider
- The infrastructure provider
- The control plane
- Custom resources
data:image/s3,"s3://crabby-images/573bd/573bd4c7c7e33021b78f4673ad8661df96325496" alt=""
Figure 11.2: Cluster API architecture
Let’s understand the role of each one of these components and how they interact with each other.
Management cluster
The management cluster...