EKS Node Migrator is a utility for to gracefully drain self-managed EKS node groups. Primarly used for draining workload from on-demand/reserverd instances so it can be scheduled over SPOT instance backed nodegroups.
Project description
EKS Node Migrator
EKS Node Migrator is a utility to gracefully drain / cordon self-managed EKS nodes in an EKS cluster.
Intro
EKS Node Migrator is a utility for gracefully draining the desired nodegroups in an EKS cluster in a rolling manner. This tool is specifically focused on scanerio where additional nodegroups are provisioned in the clusters and workload is to be shifted from the older nodegroups to the newer ones. It can be specially useful in the case when a cluster is provisioned with new nodegroups based on SPOT instances and older nodegroups are to be depcreated. This tool will only take care of node drain / cordon process, scaling down the ASGs and / or removing the nodes from the cluster is not part of the process at the momment.
To achieve this, it performs the following actions:
- Finds a list of desired ASGs and node hostnames via provided nodegroup and cluster name
- Stores the node details on which the target 'action' is to be performed
- Perform drain / cordon operations on the stored list of nodes with provided nodegroup in a rolling manner
- During the drain/cordon process, the tool keeps checking the cluster workload health (POD health), bad health for longer duration halts the process
- Ensures the ASGs are healthy and that the new nodes have joined the EKS cluster
- The tool is designed to work on one nodegroup in the cluster at a time
This tool is inspired by https://github.com/hellofresh/eks-rolling-update
Requirements
- kubectl installed
KUBECONFIG
environment variable set, or config available in${HOME}/.kube/config
per default- AWS credentials configured
Installation
From PyPi
$ mkdir ~/apps
$ mkdir ~/apps/eks-node-migrator
$ cd ~/apps/eks-node-migrator
$ virtualenv .env
$ source .env/bin/activate
(.env)$ pip install eks-node-migrator
$ cd /usr/local/bin
$ sudo ln -s ~/apps/myutil/.env/bin/eks_node_migrator.py
From source
virtualenv -p python3 venv
source venv/bin/activate
pip3 install -r requirements.txt
Usage
usage: eks_node_migrator.py [-h] --cluster_name CLUSTER_NAME --nodegroup NODEGROUP --action ACTION
The tool to perform eks node drain/cordon ops
optional arguments:
-h, --help show this help message and exit
--cluster_name CLUSTER_NAME, -c CLUSTER_NAME
the cluster name to perform drain/cordon operation on
--nodegroup NODEGROUP, -ng NODEGROUP
the nodegroup name to perform drain/cordonupdate on
--action ACTION, -a ACTION
the action to be performed i.e. drain or cordon
Example:
eks_node_migrator.py -c my-eks-cluster -ng monitoring -a cordon
eks_node_migrator.py -c my-eks-cluster -ng monitoring -a drain
Configuration
Environment Variable | Description | Default |
---|---|---|
AWS_DEFAULT_REGION | Default AWS Region to execute the script on | eu-west-1 |
BETWEEN_NODES_WAIT | Number of seconds to wait after removing a node before continuing on | 0 |
K8S_CONTEXT | Context from the Kubernetes config to use. If this is left undefined the current-context is used | None |
K8S_PROXY_BYPASS | Set to true to ignore HTTPS_PROXY and HTTP_PROXY and disable use of any configured proxy when talking to the K8S API | False |
EXTRA_DRAIN_ARGS | Additional space-delimited args to supply to the kubectl drain function, e.g --force=true . See kubectl drain -h |
"" |
Examples
- Apply Changes
$ python eks_node_migrator.py --cluster_name YOUR_EKS_CLUSTER_NAME --nodegroup WORKER-NG-01 --action cordon
- Environment Variable
In order to modify default values for env varibales, please use it by exporting it the as follow:
$ export BETWEEN_NODES_WAIT=30
- Configure tool via
.env
file
Rather than using environment variables, you can use a .env
file within your working directory to load
updater settings. e.g:
$ cat .env
BETWEEN_NODES_WAIT=30
Docker
Please feel free to use the included Dockerfile to build your own image.
make docker-dist version=1.0.DEV
After building the image, run using the command
docker run -ti --rm \
-e AWS_DEFAULT_REGION \
-e AWS_PROFILE \
-v "${HOME}/.aws:/root/.aws" \
-v "${HOME}/.kube/config:/root/.kube/config" \
eks-node-migrator:latest \
-c beta-spot-dev-sre-eks \
-ng worker-ng-spot-1 \
-a drain
Pass in any additional environment variables and options as described elsewhere in this file.
License
This project is licensed under the Apache 2.0 License - see the LICENSE file for details
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file eks-node-migrator-1.0.5.tar.gz
.
File metadata
- Download URL: eks-node-migrator-1.0.5.tar.gz
- Upload date:
- Size: 12.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.2 importlib_metadata/3.10.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.8.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 231bd2141566467687d0616801f70d71dbad5eab7a0b40f358704b03bc7d1254 |
|
MD5 | 937f9f6e1603e0193da9dbfe132bc310 |
|
BLAKE2b-256 | 00c552df8da101863c4319b397363414d095e668af4a83b3565eb59bb328f18a |