Skip to content

Commit

Permalink
Add user facing doc for management-components upgrade
Browse files Browse the repository at this point in the history
  • Loading branch information
d8660091 committed Feb 22, 2024
1 parent fa39980 commit 0938f47
Showing 1 changed file with 71 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,71 @@
---
title: "Upgrade management components"
linkTitle: "Upgrade management components"
weight: 21
aliases:
/docs/tasks/cluster/cluster-upgrades/management-components-upgrade/
date: 2024-02-21
description: >
How to perform management components upgrade for management clusters
---

>**_NOTE:_** The `upgrade management-components` sub-command is added in `eksctl anywhere` version `v0.19.0` for all providers. Management components upgrades can only be done through the `eksctl anywhere` cli, not through the Kubernetes API.
### What are “management components”?

Management components are the Kubernetes resources in an EKS Anywhere management cluster that are responsible for managing the EKS Anywhere clusters' lifecycle. Key components include, but are not limited to:

* The `eksa-controller-manager` pod located in the `eksa-system` namespace.
* Tinkerbell services located in a Bare Metal management cluster.
* Custom Resource Definitions (CRDs) such as `clusters`, `eksareleases`, and `tinkerbellmachineconfigs`.

### Why upgrade management components separately?

The `upgrade cluster` command, when executed against a management cluster, not only upgrades its management components but also initiates a comprehensive upgrade of the management cluster itself. This process often entails node replacement and significant operational tasks, which might be deemed risky for some production environments due to the potential of replacing all Kubernetes nodes.

However, to leverage enhancements to newer EKS Anywhere version, such as bug fixes in the new management components without the extensive risk, it's advisable to initially upgrade only the management components. This step ensures minimal disruption and risk. Subsequently, you can proceed to upgrade the workload cluster at a more convenient time, once you're confident in the stability and readiness of your environment. This strategy provides a more controlled and efficient method to update your cluster's management infrastructure, aligning upgrades with your readiness and risk tolerance levels.

### Check management components versions

You can check the current and new versions of management components with the `upgrade plan management-components` command:

```
eksctl anywhere upgrade plan management-components -f management-cluster.yaml
```

The output should appear similar to the following:

```
NAME CURRENT VERSION NEXT VERSION
EKS-A Management v0.18.3+cc70180 v0.19.0+a672f31
cert-manager v1.13.0+68bec33 v1.13.2+a34c207
cluster-api v1.5.2+b14378d v1.6.0+04c07bc
kubeadm v1.5.2+5762149 v1.6.0+5bf0931
vsphere v1.7.4+6ecf386 v1.8.5+650acfa
etcdadm-bootstrap v1.0.10+c9a5a8a v1.0.10+1ceb898
etcdadm-controller v1.0.16+0ed68e6 v1.0.17+5e33062
```

Alternatively, you can run `upgrade plan cluster` command against your management cluster, which should give you the version differences for both management and non-management components.

### Perform management components upgrade

To perform the upgrade, run the following command:

```
eksctl anywhere upgrade management-components -f management-cluster.yaml
```

The output should appear similar to the following:

```
Performing setup and validations
✅ Docker provider validation
✅ Control plane ready
✅ Cluster CRDs ready
Upgrading core components
Installing new eksa components
🎉 Management components upgraded!
```

At this point, a new `eksaVersion` will be available in your management cluster. If you want to upgrade your workload cluster, you can still run "eksctl anywhere upgrade cluster" or simply edit your workload cluster's `eksaVersion` field and apply it.

0 comments on commit 0938f47

Please sign in to comment.