MicroK8s CAPI - management cluster ops

In this HowTo we build on the Cluster Provisioning with CAPI guide to demonstrate two
useful operations in the lifecycle of the CAPI management cluster:

  • the upgrade of providers
  • the migration of the management workloads to another cluster

Upgrading the providers of a management cluster

Prerequisites

We assume we already have a management cluster and the infrastructure provider configured as described in the Cluster Provisioning with CAPI guide. The selected infrastructure provider is AWS. We have not yet called clusterctl init to initialise the cluster.

Initialise the cluster

To demonstrate the steps of upgrading the management cluster, we will begin by initialising an old version of the MicroK8s CAPI providers.

To set the version of the providers to be installed we use the following notation:

clusterctl init --bootstrap microk8s:v0.4.0 --control-plane microk8s:v0.4.0 --infrastructure aws

Check for updates

With clusterctl we can check if there are any new versions on the running providers:

clusterctl upgrade plan

The output shows the existing version of each provider as well as the version that we can upgrade into:

NAME                     NAMESPACE                            TYPE                     CURRENT VERSION   NEXT VERSION
bootstrap-microk8s       capi-microk8s-bootstrap-system       BootstrapProvider        v0.4.0            v0.5.0
control-plane-microk8s   capi-microk8s-control-plane-system   ControlPlaneProvider     v0.4.0            v0.5.0
cluster-api              capi-system                          CoreProvider             v1.3.5            Already up to date
infrastructure-aws       capa-system                          InfrastructureProvider   v2.0.2            Already up to date

Trigger providers upgrade

To apply the upgrade plan recommended by clusterctl upgrade plan simply:

clusterctl upgrade apply --contract v1beta1

To upgrade each provider one by one, issue:

clusterctl upgrade apply --bootstrap capi-microk8s-bootstrap-system/microk8s:v0.5.0
clusterctl upgrade apply --control-plane capi-microk8s-control-plane-system/microk8s:v0.5.0

Migrate the managment cluster

Management cluster migration is a really powerful operation in the cluster’s lifecycle as it allows admins
to move the management cluster in a more reliable substrate or perform maintenance tasks without disruptions.

Prerequisites

In the Cluster Provisioning with CAPI guide we showed how to provision a workloads cluster. Here, we start from the point where the workloads cluster is available and we will migrate the management cluster to the one cluster we just provisioned.

Install the same set of providers to the provisioned cluster

Before migrating a cluster, we must make sure that both the target and source management clusters run the same version of providers (infrastructure, bootstrap, control plane). To do so clusterctl init should be called against he target cluster:

clusterctl get kubeconfig <provisioned-cluster> > targetconfig
clusterctl --kubeconfig=$PWD/targetconfig --bootstrap microk8s --control-plane microk8s --infrastructure aws

Move the cluster

Simply call:

clusterctl move --to-kubeconfig=$PWD/targetconfig

Links:

Provider upgrade: upgrade - The Cluster API Book
Cluster API move: move - The Cluster API Book