Kubernetes-native declarative infrastructure for Metal3.
The Cluster API brings declarative,
Kubernetes-style APIs to cluster creation, configuration and management. The API
itself is shared across multiple cloud providers. Cluster API Provider Metal3 is
one of the providers for Cluster API and enables users to deploy a Cluster API based
cluster on top of bare metal infrastructure using Metal3.
Compatibility with Cluster API
CAPM3 version |
Cluster API version |
CAPM3 Release |
v1alpha4 |
v1alpha3 |
v0.4.X |
v1alpha5 |
v1alpha4 |
v0.5.X |
v1beta1 |
v1beta1 |
v1.0.X |
The recommended method is using
Clusterctl.
Starting from v0.5.0
release of Cluster-api-provider-metal3, Baremetal Operator is decoupled
from Cluster-api-provider-metal3 deployments when deployed via clusterctl
. For that reason,
Baremetal Operator will not be installed when initializing the Metal3 provider with clusterctl,
and its CRDs and controller need to be manually installed. Example flow of installing Metal3
provider:
-
Install Cluster API core, bootstrap and control-plane providers. This will also install
cert-manager if it is not already installed.
clusterctl init --core cluster-api:v0.4.4 --bootstrap kubeadm:v0.4.4 \
--control-plane kubeadm:v0.4.4 -v5
-
Install Metal3 provider. This will install Cluster-api-provider-metal3 CRDs and controllers.
clusterctl init --infrastructure metal3
-
Deploy Baremetal Operator manifests and CRDs. You need to install cert-manager for Baremetal Operator,
but since step 1 already does it, we skip it here and only install the operator. Depending on
whether you want TLS, or basic-auth enabled, kustomize paths may differ. Check operator dev-setup doc
for more info.
git clone https://github.com/metal3-io/baremetal-operator.git
cd baremetal-operator
kustomize build config/default | kubectl apply -f -
-
Install Ironic. There are a couple of ways to do it.
- Run within a Kubernetes cluster as a pod, refer to deploy.sh
script.
- Outside of a Kubernetes cluster as a container. Please refer to run_local_ironic.sh.
Please refer to the getting-started for more info.
Pivoting ⚠️
Starting from v0.5.0
release of Cluster-api-provider-metal3, Baremetal Operator is decoupled
from Cluster-api-provider-metal3 deployments when deployed via clusterctl
. For that reason,
when performing clusterctl move
, custom objects outside of the Cluster API chain or not part
of CAPM3 will not be pivoted to a target cluster. Example to those objects is BareMetalHost, its
secret and configMap which are reconciled by Baremetal Operator. To ensure that those objects are
also pivoted as part of clusterctl move
, clusterctl.cluster.x-k8s.io
label need to be set
on the BareMetalHost CRD before pivoting. If there are other CRDs also need to be pivoted to target
cluster, the same label needs to be set on them.
All the other objects owned by BareMetalHost, such as Secret and ConfigMap don't require this
label to be set, because they hold ownerReferences to BareMetalHost, and that is good enough
for clusterctl to move all the hierarchy of BareMetalHost object.
Development Environment
There are multiple ways to setup a development environment:
API
See the API Documentation for details about the objects used with
this cluster-api
provider. You can also see the cluster deployment
workflow for the outline of the
deployment process.
Architecture
The architecture with the components involved is documented here
E2E test
To trigger e2e test on a PR, use the following phrases:
On main branch:
- /test-v1b1-e2e runs v1b1 e2e tests on Ubuntu
- /test-v1b1-centos-e2e runs v1b1 e2e tests on CentOS
Release-0.5 branch:
- /test-v1a5-e2e runs v1a5 e2e tests on Ubuntu
- /test-v1a5-centos-e2e runs v1a5 e2e tests on CentOS
More info about e2e test can be found here