Working under the hood to stop disruptions to your AKS nodes
mechanic is a tool for AKS clusters that helps mitigate the impact from platform maintenance events. Its primary focus is preventing application impacts from maintenance events that require node reboots or live migrations without moving pods unnecessarily or causing application downtime.
It does this by monitoring node conditions and, when a maintenance event is indicated, querying the Instance Metadata Service for maintenance event details. If the event is deemed impactful to the node, it will cordon and drain the node to ensure pods are rescheduled to other nodes before the maintenance event occurs.
The best combination of functionality would be using this alongside Cluster Autoscaler. The built-in node problem detector
implementation used by AKS will manage the VMEventScheduled
node condition which triggers this drain functionality.
As the pods are drained from the node, without Cluster Autoscaler the cluster could exhaust available compute resources; using CAS or Node Autoprovisioning would ensure that the cluster can scale to meet the demands of the pods being rescheduled.
tl;dr -
kubectl apply -f deploy/static/mechanic.yaml
for the default configuration and latest prod image.
The recommended way to run mechanic is through a DaemonSet - this ensures that each node in the cluster has a monitor that can coordinate cordon and drain operations. There are some limitations at this time - namely:
- No support for Windows nodes running on ARM64 SKUs.
Mechanic is offered as a base set of YAMLs that can be applied to your cluster through the use of kustomize. For details on generating valid YAML to install the DaemonSet, see the installation guide.
There are some caveats and items worth noting:
- The DaemonSet is deployed in a custom
mechanic
namespace. This is to ensure that the DaemonSet can be managed independently of other resources in the cluster. - The Kustomize base offers a prebuilt image hosted in the GitHub Container Registry packages of this repository. If you choose, you can build your own image or pull the image from the GitHub Container Registry for this project and push it into your own registry. Once the image is in a registry, you can create a patch to have Kustomize update the image URL.
- All images use a base container image of Azure Linux.
mechanic runs as a DaemonSet in your cluster. Each daemon pod monitors node updates and, for each update, checks the
node conditions. If a VMEventScheduled
condition is present, it queries the Instance Metadata Service for maintenance
information.
If the maintenance event is deemed impactful, it will cordon the node and begin draining pods to other nodes in the cluster.
During the drain flow, a label is added to the node (mechanic.cordoned
) indicating that it was cordoned by mechanic. If the daemon pod is restarted,
it will check for this label and use it as an input on whether to uncordon the node if the VMEventScheduled
condition is
no longer present.
Great! We're always looking for contributors to help improve the project. If you're interested in contributing, please see the contributing docs for more information on how to get started.