Go to file
dlorenc ac14eff554 Move the addon-manager and dashboard configuration from the iso to minikube.
Minikube now copies these into the VM, just like it copies in localkube.
New ISOs will not contain these files, but this is compatible with the existing ISO
because minikube will overwrite existing files.
2016-06-09 15:35:09 -07:00
Godeps Added gen_help_text.go and docs/ directory for cobra generated help 2016-06-07 16:44:06 -07:00
cmd Added dashboard cmd to minikube. Also added dependencies via godep. 2016-06-07 11:43:47 -07:00
deploy Move the addon-manager and dashboard configuration from the iso to minikube. 2016-06-09 15:35:09 -07:00
docs Fix the help text. I merged two commits at the same time, and they conflicted. 2016-06-07 17:40:11 -07:00
hack Remove the hardcoded constant. 2016-06-03 15:23:35 -07:00
pkg Move the addon-manager and dashboard configuration from the iso to minikube. 2016-06-09 15:35:09 -07:00
test/integration Switch more tests to EnsureRunning. 2016-06-06 11:41:27 -07:00
vendor Added gen_help_text.go and docs/ directory for cobra generated help 2016-06-07 16:44:06 -07:00
.gitignore Move the addon-manager and dashboard configuration from the iso to minikube. 2016-06-09 15:35:09 -07:00
.travis.yml Add a Makefile to replace build.sh and test.sh. 2016-05-04 14:45:06 -07:00
CHANGELOG.md Release notes. 2016-06-03 12:31:27 -07:00
CONTRIBUTING.md Add CONTRIBUTING.md 2016-04-25 10:42:07 -07:00
LICENSE Update License file 2016-04-15 15:44:00 -07:00
Makefile Move the addon-manager and dashboard configuration from the iso to minikube. 2016-06-09 15:35:09 -07:00
README.md README: add contact points for community 2016-06-08 22:33:49 -07:00
ROADMAP.md Address feedback. 2016-06-07 15:41:31 -07:00
gen_help_text.go Fix the help text. I merged two commits at the same time, and they conflicted. 2016-06-07 17:40:11 -07:00
test.sh Move the addon-manager and dashboard configuration from the iso to minikube. 2016-06-09 15:35:09 -07:00

README.md

Minikube

Run Kubernetes locally

Build Status

Background

Minikube is a tool that makes it easy to run Kubernetes locally. Minikube runs a single-node Kubernetes cluster inside a VM on your laptop for users looking to try out Kubernetes or develop with it day-to-day.

Requirements For Running Minikube

  • VirtualBox installation
  • VT-x/AMD-v virtualization must be enabled in BIOS

Installation

See the installation instructions for the latest release.

Usage

Here's a brief demo of minikube usage. We're using the code from this Kubernetes tutorial. Note that the IP below is dynamic and can change. It can be retrieved with minikube ip.

$ minikube start
Starting local Kubernetes cluster...
Running pre-create checks...
Creating machine...
Starting local Kubernetes cluster...
Kubernetes is available at https://192.168.99.100:443.

$ eval $(minikube docker-env)
$ docker build -t helloworld .
Successfully built d16fe85e1abe
$ kubectl run hello-minikube --image=helloworld --hostport=8000 --port=8080 --generator=run-pod/v1
pod "hello-minikube" created
$ curl http://$(minikube ip):8000
Hello World!
$ minikube stop
Stopping local Kubernetes cluster...
Stopping "minikubeVM"...

Documentation

For a list of minikube's available commands see: minikube docs

Dashboard

To access the dashboard, run this command in a shell after starting minikube to get the address:

echo $(minikube ip):$(kubectl get service kubernetes-dashboard --namespace=kube-system -o=jsonpath='{.spec.ports[0].nodePort}{"\n"}')

And then copy/paste that into your browser.

Features

  • Minikube packages and configures a Linux VM, Docker and all Kubernetes components, optimized for local development.
  • Minikube supports Kubernetes features such as:
    • DNS
    • NodePorts
    • ConfigMaps and Secrets
    • Dashboards

Known Issues

  • Features that require a Cloud Provider will not work in Minikube. These include:
  • LoadBalancers
  • PersistentVolumes
  • Ingress
  • Features that require multiple nodes. These include:
  • Advanced scheduling policies
  • DaemonSets
  • Alternate runtimes, like rkt.

If you need these features, don't worry! We're planning to add these to minikube over time. Please leave a note in the issue tracker about how you'd like to use minikube!

Design

Minikube uses libmachine for provisioning VMs, and localkube (originally written and donated to this project by RedSpread) for running the cluster.

For more information about minikube, see the proposal.

Goals and Non-Goals

For the goals and non-goals of the minikube project, please see our roadmap.

Development Guide

See CONTRIBUTING.md for an overview of how to send pull requests.

Build Requirements

  • A recent Go distribution (>1.6)
  • If you're not on Linux, you'll need a Docker installation
  • Minikube requires at least 4GB of RAM to compile, which can be problematic when using docker-machine

Build Instructions

make out/minikube

Run Instructions

Start the cluster using your built minikube with:

$ ./out/minikube start

Running Tests

Unit Tests

Unit tests are run on Travis before code is merged. To run as part of a development cycle:

make test

Integration Tests

Integration tests are currently run manually. To run them, build the binary and run the tests:

make integration

Conformance Tests

These are kubernetes tests that run against an arbitrary cluster and exercise a wide range of kubernetes features. You can run these against minikube by following these steps:

  • Clone the kubernetes repo somewhere on your system.
  • Run make quick-release in the k8s repo.
  • Start up a minikube cluster with: minikube start.
  • Set these two environment variables:
export KUBECONFIG=$HOME/.kube/config
export KUBERNETES_CONFORMANCE_TEST=y
  • Run the tests (from the k8s repo):
go run hack/e2e.go -v --test --test_args="--ginkgo.focus=\[Conformance\]" --check_version_skew=false --check_node_count=false

Community

Contributions, questions, and comments are all welcomed and encouraged! minkube developers hang out on Slack in the #minikube channel (get an invitation here). We also have the kubernetes-dev Google Groups mailing list. If you are posting to the list please prefix your subject with "minikube: ".