SilphRoad / Marver

A Discord bot shard autoscaler for Kubernetes

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Marver

Codacy Badge Docker Repository on Quay

Marver is a K8s StatefulSet autoscaler that uses the Discord Gateway Bot endpoint to determine the recommended number of shards and automatically scale up when Discord recommends it.

This project requires that you already be using Kubernetes, and assume you have some understand of how Kubernetes works. It also assumes that you have your bot set up to handle changes in the StatefulSet's replica count gracefully. Meaning: if we scale up, all existing shards will need to re-identify with Discord to present the new shard count, and update their local cache as necessary.

Getting Started

  1. Edit the glide.yaml to change the Kubernetes library version to the one that matches your cluster version. You can find a compatibility matrix on the client-go Github repository.
  2. Store the Discord bot token and webhook ID + token in Kubernetes secrets.
  3. Edit kubernetes/cronjob.yaml and change the environment variables to match your set up.
  4. Apply the Kubernetes configurations to the namespace your bot is in, and watch it autoscale :-D

About

A Discord bot shard autoscaler for Kubernetes

License:GNU General Public License v3.0


Languages

Language:Go 89.1%Language:Dockerfile 10.9%