Coder Social home page Coder Social logo

rotatorctl's Introduction

Rotatorctl_Logo

CLI tool for smoothing and accelerating k8s cluster upgrades and node rotations.

rotatorctl (Rotator CLI)

rotatorctl (Rotator CLI) uses the Mattermost Rotator module to smooth and accelerate k8s cluster upgrades and node rotations. It offers automation on an autoscaling group recognition and flexibility on options such as how fast to rotate nodes, drain retries, waiting time between rotations and drains as well as mater/worker node separation.

How to use

Get or build the release binaries and use it as a CLI locally or in any pipeline to automate nodes rotation.

Building

Simply run the following:

go install ./cmd/rotatorctl
alias rotatorctl='$HOME/$GOROOT/bin/rotatorctl'

or use the make shorthands

For Linux binary: make build

For MacOS (darwin) binary: make build-mac

Running

To rotate a cluster:

rotatorctl rotate --cluster <cluster_name>  --wait-between-rotations 30 --wait-between-drains 60 --max-scaling 4 --evict-grace-period 30

Other Setup

For the rotatorctl to run access to both the AWS account and the K8s cluster, it is required to be able to do actions such as, DescribeInstances, DetachInstances, TerminateInstances, DescribeAutoScalingGroups, as well as drain, kill, evict pods, etc.

The relevant AWS Access and Secret key pair should be exported and k8s access should be provided via a passed clientset or a locally exported k8s config.

rotatorctl's People

Contributors

azigler avatar jwilander avatar spirosoik avatar stafot avatar

Stargazers

 avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

rotatorctl's Issues

Is this tool useful for EKS with Managed Node Group?

Scenario

Consider the K8s cluster is EKS with Managed Node Group. In case of EKS upgrade, we need to rotate out the Managed Node Groups with the new AMI with updated version of Kubelet and other changes. AWS EKS do the rotation painlessly, however, just trying to implement some customisation to manage timing. Saw the parameter "--wait-between-rotations" in rotatorctl. Just trying to explore more here.

Questions

  1. Does this support EKS with Managed Node Group by any chance?
  2. Any similar tool available for EKS with Managed Node Group?

I went through the doc https://mattermost.com/blog/automate-eks-node-rotation/ and it says following:

After we adopted AWS EKS managed nodes, we simplified our Gitlab pipelines by dropping our custom rotation mechanism, as managed nodes offer natively their own.

Just confirming.

Thanks in advance!

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.