Skip to content

A user-friendly controller to create and manage kubernetes clusters on AWS

Notifications You must be signed in to change notification settings

200106-uta-go/BAM-P2

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

GitHub release (latest by date including pre-releases) Go Report Card

BAM

Brandon, Aaron, and Matt -- Revature-Project 2

BAM is an easy to use tool to create and manage a Kubernetes cluster on AWS. BAM gives user the ability to quickly spin up a kubernetes cluster on AWS from your host machine and then deploys a simple interface locally to control your cluster deployment.

Getting Started

To get started created a Kubernetes cluster on AWS with BAM, run the startup executable and follow the instructions to get your host machine set up to connect to AWS. The startup program will then prompt you for information about the cluster you want to create. Once all the user information has been recieved, BAM will deploy your cluster on AWS.

To control your cluster, launch the Controller application and use your browser to access http://localhost:4040/web to get to the cluster controller interface.

Using the installer

The installer is packaged with two binaries, one for dependency installation, and one for deploying the cluster to AWS.

The only prerequisite to running the installer is to have an AWS account and a generated key pair so that KOPS can start ec2 and s3 instances for your cluster.

If your machine does not have kops, kubectl, or aws cli installed, you need to run the Installer before a cluster can be created. Once the Installer has run, or if you already have all the necessary programs installed, you can run the Deploy executable to launch your kubernetes cluster on AWS.

Using the Web Interface

The BAM web interface allows the user to wasily control a cluster from their host machine. Once your cluster has been created, you need to add a deployment to start running container in your kubernetes pods.

The web interface provides two ways to create a deployment. Id you have a .yaml formatted deployment ready to go, you can paste your deployment into the text box that appears when you click the add deployment button. Services must be created using a deployment using .yaml formatted text in the apply deployment window.

Image of add deployment button

The other way you can start a deployment is to add a new pod using a container image name from DockerHub. Make sure to include the user if present and the version you want to deploy.

Image of add pod button

Once your deployment is running, you can increase and decrease the pod replicas for each deployment using the buttons next to the pods header.

Image of scale buttons

You can view the logs for the pod and delete the pod from your deployment using the buttons on the bottom of each pod's details.

Development

To get started with a development environment for this project, you only need a go installation and the go dependencies for each application. These can be retrieved using:

go get -d

You will find multiple different applications in the command package, most of which were designed to be used inside containers running on a kubernetes cluster. The makefile has scripts to create docker images and deploy each app into a docker container. The apps can also be built into a go binary for easy testing during development.

Built With

  • KOPS - The cluster creation tool used
  • Kubernetes - Cluster management and networking