The easiest way to get a production grade Kubernetes cluster up and running.
We like to think of it as kubectl
for clusters.
kops
lets you deploy production-grade, highly available, Kubernetes clusters
from the command line. Deployment is currently supported on Amazon Web
Services (AWS), with more platforms planned.
To replicate the above demo, check out our tutorial for launching a Kubernetes cluster hosted on AWS.
- Automate the provisioning of Kubernetes clusters in (AWS)
- Deploy Highly Available (HA) Kubernetes Masters
- Supports upgrading from kube-up
- Built on a state-sync model for dry-runs and automatic idempotency
- Ability to generate Terraform configuration
- Supports custom add-ons for
kubectl
- Command line autocompletion
- Community supported!
kubectl
is required, see here.
$ brew update && brew install kops
Download the latest release, then:
$ chmod +x kops-linux-amd64 # Add execution permissions
$ mv kops-linux-amd64 /usr/local/bin/kops # Move the kops to /usr/local/bin
Go 1.7+ and make are required. You may need to do a full build including pushing protokube, nodeup, and kops to s3. See the install notes for more information.
$ go get -d k8s.io/kops
$ cd ${GOPATH}/src/k8s.io/kops/
$ git checkout release
$ make
At this time, Windows is not a supported platform.
See the releases for more information on changes between releases.
Are you interested in contributing to kops? We the maintainers and community would love your suggestions, contributions, and help! We have a quickstart guide on adding a feature and the maintainers can be contacted at any time to learn more about how to get involved.
Kops maintainers also have time (1 hour) set aside every other week to offer help and guidance to the community. This is the maintainer's office hours. During this time we might work with newcomers, help with PRs, and discuss new features. Anything goes.
We encourage you to reach out beforehand if you plan on attending. We have an agenda where we track notes from office hours.
Office hours, on Zoom video conference are on Fridays at 5pm UTC/9 am US Pacific every other week, on odd week numbers.
You can check your week number using:
date +%V
The maintainers and other community members are generally available on the kubernetes slack in #kops, so come find and chat with us about how kops can be better for you!
- Create kubecfg settings for kubectl
- Set up add-ons, to add important functionality to Kubernetes
- Learn about InstanceGroups; change instance types, number of nodes, and other options
- Read about networking options
- Look at our other interesting modes
- Full command line interface documentation
If you think you have found a bug please follow the instructions below.
- Please spend a small amount of time giving due diligence to the issue tracker. Your issue might be a duplicate.
- Set
-v 10
command line option and save the log output. Please paste this into your issue. - Note the version of kops you are running (from
kops version
), and the command line options you are using - Open a new issue
- Remember users might be searching for your issue in the future, so please give it a meaningful title to helps others.
- Feel free to reach out to the kops community on kubernetes slack
We also use the issue tracker to track features. If you have an idea for a feature, or think you can help kops become even more awesome follow the steps below.
- Open a new issue
- Remember users might be searching for your issue in the future, so please give it a meaningful title to helps others.
- Clearly define the use case, using concrete examples. EG: I type
this
and kops doesthat
. - Some of our larger features will require some design. If you would like to include a technical design for your feature please include it in the issue.
- After the new feature is well understood, and the design agreed upon we can start coding the feature. We would love for you to code it. So please open up a WIP (work in progress) pull request, and happy coding.