Minikube:轻松运行本地 Kuberntes 集群
原文:Minikube: easily run Kubernetes locally
Kubernetes 已经是目前最佳的应用容器化工具之一。在投入实际使用之后的一年来,Kubernetes(社区)需要一个本地开发平台。
在过去的几个月中,Kubernetes 社区中的很多成员在为 Github 的 Minikube 仓库 奋战。我们要建立一个可以一键运行的版本,这个版本要易用和准确兼顾,并且能够兼容 Mac、 Linux 以及 Windows 的工作站和笔记本电脑。
感谢社区成员的贡献,我们自豪的宣告 Minikube 的诞生,并与 Kubernetes 1.3 一起发布,新的命令能够更好的跟本地集群通信,并且加入了试验性的对 xhyve(OS X)以及 KVM(Linux)的支持。
使用 Minikube
Minitube 是一个独立的 Go 应用,所以只要下载运行就可以了:
Minikube 目前要求安装 VirtualBox
# 这是针对 Mac, 如果是 Linux 的话,用 minikube-linux-amd64 代替 minikube-darwin-amd64 即可
curl -Lo minikube https://storage.googleapis.com/minikube/releases/latest/minikube-darwin-amd64 && chmod +x minikube && sudo mv minikube /usr/local/bin/
要启动 Kubernetes 集群,要使用minikube start
命令:
$ minikube start
Starting local Kubernetes cluster...
Kubernetes is available at https://192.168.99.100:443
Kubectl is now configured to use the cluster
这样,就在你的电脑上启动了一个单节点的 Kubernetes 集群。Minikube 会给你配置 kubectl
,所以你现在就可以运行容器了。
Minikube 创建了一个 Host-Only 的网络界面来和 Node 通信。要和其中的 Pod 或者 Service 通信,就需要跟这个地址进行交互。可以使用 minikube ip
命令:
Minikube 还自带了 Kubernetes Dashboard。要浏览这个界面,可以使用内置的 minikube dashboard
命令。
一般来说,Minikube 支持 Kubernetes 集群的所有内容。你可以使用 kubectl exec
来在 pod 内获取一个 bash shell。还可以使用 kubectl port-forward
以及 kubectl proxy
命令来把通信从本地转发到一个 pod 或者 API server。
Minikube 是运行在本地而不是云供应商,因此特定的 LoadBalancer 以及 PersistentVolume 也就无法使用了;当然,还是可以使用 NodePort 以及 HostPath 作为替代方案。
架构
Minikube 构建于 Docker 的 libmachine,利用他的驱动模型来创建、管理本地运行的虚拟机,并与其交互。
慷慨的 RedSpread向 Minikube 贡献了他们的 localkube 代码,得到这一帮助,我们有了在虚拟机中创建单进程 Kubernetes 集群的能力。Localkube 把 etcd、DNS、Kubelet 以及所有的 Kubernetes Master 组件都集成到了一个单独的 Go Lib 中并使用不同的 goroutine 执行。
后续发展
Minikube 现在已经颇具可玩性了,为了改善 Kubernetes 开发体验,我们会持续对 Minikube 进行增强。如果你有任何设想,请移步 issue tracker 畅所欲言。
我们希望尽快把下面列表中的内容加入 Minikube:
- 为 OSX 以及 Windows 提供本地的 Native hypervisor 支持。
- 我们计划去掉对 Virtualbox 的依赖,转向 OSX 和 Windows 的本地 Hypervisor。
- 增强对 Kubernetes 特性的支持
- 希望能够进一步缩小功能差异,以便于引入 Ingress 之类的内容。
- 可配置的 Kubernetes 版本
- 目前 Minikube 只支持 Kubernetes 1.3。我们计划提供用户可控的 Kubernetes 版本支持,这样就能够让开发与生产环境更加贴近。
社区
我们乐于听取 Minikube 的反馈,可以用下面的方式参与社区:
请给 Minikube 一个机会,并让我们能够获知 Minikube 的运行情况。