Go to file
Aaron Prindle 6017e34d4d Fixed integration tests, adding test output to ssh mock, change help text to use multi-line string and
updated docs.
2016-09-08 13:13:15 -07:00
.github Remove kernel field from issue templ 2016-08-16 11:23:21 -07:00
Godeps Add hyperv support 2016-08-24 16:16:07 +01:00
cmd Fixed integration tests, adding test output to ssh mock, change help text to use multi-line string and 2016-09-08 13:13:15 -07:00
deploy Merge pull request #542 from r2d4/releases-json 2016-09-02 09:43:52 -07:00
docs Fixed integration tests, adding test output to ssh mock, change help text to use multi-line string and 2016-09-08 13:13:15 -07:00
hack Add a script to generate coverage results. 2016-07-14 10:43:42 -07:00
installers/linux/deb/minikube_deb_template/DEBIAN Added installers directory and a populated the linux .deb installer 2016-08-29 09:49:29 -07:00
logo Added more logo types 2016-08-15 17:43:35 +01:00
pkg Fixed integration tests, adding test output to ssh mock, change help text to use multi-line string and 2016-09-08 13:13:15 -07:00
test/integration Fixed integration tests, adding test output to ssh mock, change help text to use multi-line string and 2016-09-08 13:13:15 -07:00
vendor Add hyperv support 2016-08-24 16:16:07 +01:00
.gitignore Add .idea to gitignore 2016-07-22 10:48:15 +01:00
.lgtm Add lgtm.co configuration 2016-07-14 21:54:21 +01:00
.travis.yml Added test coverage monitoring. Also added comments to test.sh changes. 2016-08-18 16:19:03 -07:00
ADD_DEPENDENCY.md Broke some things out of the main README.md to make it a more manageable size 2016-09-01 15:10:33 -07:00
BUILD_GUIDE.md Broke some things out of the main README.md to make it a more manageable size 2016-09-01 15:10:33 -07:00
CHANGELOG.md Initial Change Log for v0.9.0 2016-09-01 13:08:12 -07:00
CONTRIBUTING.md Add CONTRIBUTING.md 2016-04-25 10:42:07 -07:00
DRIVERS.md Add more detailed instructions for the kvm driver 2016-07-13 17:50:54 +01:00
LICENSE Update License file 2016-04-15 15:44:00 -07:00
LOCALKUBE_RELEASING.md Added localkube caching functionality. Also cleanup up private/public 2016-08-08 11:50:57 -07:00
MAINTAINERS Add mrick to maintainers 2016-09-02 10:04:18 -07:00
Makefile Bump minikube to v0.9.0 2016-09-01 13:38:06 -07:00
README.md Add warning to avoid imagePullPolicy:Always. 2016-09-05 21:14:36 +01:00
RELEASING.md Add ISO checksum validation. 2016-08-20 17:33:50 -07:00
ROADMAP.md Address feedback. 2016-06-07 15:41:31 -07:00
UPDATE_KUBERNETES.md Broke some things out of the main README.md to make it a more manageable size 2016-09-01 15:10:33 -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 Use double brackets instead of single for boilerplate test 2016-09-06 11:09:30 -07:00

README.md

Minikube

Build Status codecov

What is Minikube?

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.

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

Installation

Requirements

  • OS X
  • Linux
  • VT-x/AMD-v virtualization must be enabled in BIOS
  • kubectl must be on your path. Minikube currently supports any version of kubectl greater than 1.0, but we recommend using the most recent version. You can install kubectl with these steps.

Instructions

See the installation instructions for the latest release.

Quickstart

Here's a brief demo of minikube usage. If you want to change the VM driver add the appropriate --vm-driver=xxx flag to minikube start. Minikube Supports the following drivers:

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:8443.

$ kubectl run hello-minikube --image=gcr.io/google_containers/echoserver:1.4 --port=8080
deployment "hello-minikube" created
$ kubectl expose deployment hello-minikube --type=NodePort
service "hello-minikube" exposed

# We have now launched an echoserver pod but we have to wait until the pod is up before curling/accessing it
# via the exposed service.
# To check whether the pod is up and running we can use the following:
$ kubectl get pod
NAME                              READY     STATUS              RESTARTS   AGE
hello-minikube-3383150820-vctvh   1/1       ContainerCreating   0          3s
# We can see that the pod is still being created from the ContainerCreating status
$ kubectl get pod
NAME                              READY     STATUS    RESTARTS   AGE
hello-minikube-3383150820-vctvh   1/1       Running   0          13s
# We can see that the pod is now Running and we will now be able to curl it:
$ curl $(minikube service hello-minikube --url)
CLIENT VALUES:
client_address=192.168.99.1
command=GET
real path=/
...
$ minikube stop
Stopping local Kubernetes cluster...
Stopping "minikube"...

Driver plugins

See DRIVERS for details on supported drivers and how to install plugins, if required.

Reusing the Docker daemon

When using a single VM of kubernetes its really handy to reuse the Docker daemon inside the VM; as this means you don't have to build on your host machine and push the image into a docker registry - you can just build inside the same docker daemon as minikube which speeds up local experiments.

To be able to work with the docker daemon on your mac/linux host use the docker-env command in your shell:

eval $(minikube docker-env)

you should now be able to use docker on the command line on your host mac/linux machine talking to the docker daemon inside the minikube VM:

docker ps

Remember to turn off the imagePullPolicy:Always, as otherwise kubernetes won't use images you built locally.

Managing your Cluster

Starting a Cluster

The minikube start command can be used to start your cluster. This command creates and configures a virtual machine that runs a single-node Kubernetes cluster. This command also configures your kubectl installation to communicate with this cluster.

Stopping a Cluster

The minikube stop command can be used to stop your cluster. This command shuts down the minikube virtual machine, but preserves all cluster state and data. Starting the cluster again will restore it to it's previous state.

Deleting a Cluster

The minikube delete command can be used to delete your cluster. This command shuts down and deletes the minikube virtual machine. No data or state is preserved.

Interacting With your Cluster

Kubectl

The minikube start command creates a "kubectl context" called "minikube". This context contains the configuration to communicate with your minikube cluster.

Minikube sets this context to default automatically, but if you need to switch back to it in the future, run:

kubectl config use-context minikube,

or pass the context on each command like this: kubectl get pods --context=minikube.

Dashboard

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

minikube dashboard

Services

To access a service exposed via a node port, run this command in a shell after starting minikube to get the address:

minikube service [-n NAMESPACE] [--url] NAME

Networking

The minikube VM is exposed to the host system via a host-only IP address, that can be obtained with the minikube ip command. Any services of type NodePort can be accessed over that IP address, on the NodePort.

To determine the NodePort for your service, you can use a kubectl command like this:

kubectl get service $SERVICE --output='jsonpath="{.spec.ports[0].NodePort}"'

Persistent Volumes

Minikube supports PersistentVolumes of type hostPath. These PersistentVolumes are mapped to a directory inside the minikube VM.

The Minikube VM boots into a tmpfs, so most directories will not be persisted across reboots (minikube stop). However, Minikube is configured to persist files stored under the following host directories:

  • /data
  • /var/lib/localkube
  • /var/lib/docker

Here is an example PersistentVolume config to persist data in the '/data' directory:

apiVersion: v1
kind: PersistentVolume
metadata:
  name: pv0001
spec:
  accessModes:
    - ReadWriteOnce
  capacity:
    storage: 5Gi
  hostPath:
    path: /data/pv0001/

Private Container Registries

To access a private container registry, follow the steps on this page.

We recommend you use ImagePullSecrets, but if you would like to configure access on the minikube VM you can place the .dockercfg in the /home/docker directory or the config.json in the /home/docker/.docker directory.

Documentation

For a list of minikube's available commands see the full CLI docs.

Using Minikube with an HTTP Proxy

Minikube creates a Virtual Machine that includes Kubernetes and a Docker daemon. When Kubernetes attempts to schedule containers using Docker, the Docker daemon may require external network access to pull containers.

If you are behind an HTTP proxy, you may need to supply Docker with the proxy settings. To do this, pass the required environment variables as flags during minikube start.

For example:

$ minikube start --docker-env HTTP_PROXY=http://$YOURPROXY:PORT \
                 --docker-env HTTPS_PROXY=https://$YOURPROXY:PORT

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
  • Alternate runtimes, like rkt.

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.

Building Minikube

For instructions on how to build/test minikube from source, see the build guide

Adding a New Dependency

For instructions on how to add a new dependency to minikube see the adding dependencies guide

Updating Kubernetes

For instructions on how to add a new dependency to minikube see the updating kubernetes guide

Steps to Release Minikube

For instructions on how to release a new version of minikube see the release guide

Steps to Release Localkube

For instructions on how to release a new version of localkube see the localkube release guide

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: ".