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

cluster starts

这样,就在你的电脑上启动了一个单节点的 Kubernetes 集群。Minikube 会给你配置 kubectl,所以你现在就可以运行容器了。

Minikube 创建了一个 Host-Only 的网络界面来和 Node 通信。要和其中的 Pod 或者 Service 通信,就需要跟这个地址进行交互。可以使用 minikube ip 命令:

minikube ip

Minikube 还自带了 Kubernetes Dashboard。要浏览这个界面,可以使用内置的 minikube dashboard命令。

dashboard command

dashboard screen shot

一般来说,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 的反馈,可以用下面的方式参与社区:

  • GitHub 中提出 Issue 或者提出功能要求。
  • 加入 Slack#minikube 频道

请给 Minikube 一个机会,并让我们能够获知 Minikube 的运行情况。

Avatar
崔秀龙

简单,是大师的责任;我们凡夫俗子,能做到清楚就很不容易了。

comments powered by Disqus
下一页
上一页

相关