minikube 介绍与快速入门 – wiki词典

Minikube 介绍与快速入门

Minikube 是一个开源工具,它允许你在本地机器上运行一个单节点 Kubernetes 集群。它专为本地开发和测试而设计,让你无需一个完整的云环境或多服务器设置,就能更轻松地体验 Kubernetes 的概念。Minikube 通过在你的本地系统上提供一个虚拟机(VM)或使用容器运行时来托管 Kubernetes 集群。

为什么选择 Minikube?

  • 本地开发环境: Minikube 提供了一个轻量级的本地 Kubernetes 环境,非常适合开发者在自己的机器上构建、测试和调试应用程序。
  • 学习和实验: 对于 Kubernetes 初学者来说,Minikube 是一个极佳的学习工具。它简化了集群的设置过程,让你能专注于 Kubernetes 的核心概念和操作。
  • 资源效率: 相比于在云端部署一个完整的 Kubernetes 集群,Minikube 在本地运行,可以更有效地利用你的本地资源。
  • 多驱动支持: Minikube 支持多种虚拟化驱动和容器运行时,例如 Docker、VirtualBox、Hyper-V、KVM、Podman 和 VMware,提供了很大的灵活性。

预备条件

在安装 Minikube 之前,请确保你的系统满足以下要求:

  • 操作系统: Linux、macOS 或 Windows。
  • 硬件:
    • 2个或更多 CPU。
    • 2GB 或更多可用内存。
    • 20GB 或更多可用磁盘空间。
  • 虚拟化/容器管理器: 例如 Docker、VirtualBox、Hyper-V、KVM、Podman 或 VMware。在安装 Minikube 之前,应先安装其中之一。
  • kubectl Kubernetes 命令行工具,用于与集群交互。

安装步骤

  1. 安装 kubectl
    kubectl 是与 Kubernetes 集群交互的必备工具。你可以通过系统包管理器安装,或从 Kubernetes 官方网站下载。

    • Linux (amd64) 示例:
      bash
      curl -LO "https://storage.googleapis.com/kubernetes-release/release/$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)/bin/linux/amd64/kubectl"
      chmod +x ./kubectl
      sudo mv ./kubectl /usr/local/bin/kubectl
  2. 安装 Minikube
    从 Minikube 官方网站下载并安装,或使用系统包管理器。

    • Linux (amd64) 示例:
      bash
      curl -Lo minikube https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64 \
      && chmod +x minikube && sudo mv minikube /usr/local/bin/
    • 验证安装:
      bash
      minikube version

启动 Minikube

安装完成后,即可启动 Minikube 集群。如果你的系统有多个虚拟化选项,可以指定驱动。

bash
minikube start --driver=<driver_name>

<driver_name> 替换为你选择的虚拟化程序(例如,dockervirtualboxkvm2hyperv)。如果你不指定驱动,Minikube 会尝试自动选择一个,通常在安装 Docker 时会默认选择 Docker。此过程会下载必要的组件并创建虚拟机,可能需要几分钟。

与 Minikube 交互

  • 检查集群状态:
    bash
    minikube status

  • 访问 Kubernetes Dashboard:
    Minikube 包含一个内置的仪表盘。
    bash
    minikube dashboard

    此命令会在你的 Web 浏览器中打开 Kubernetes 仪表盘。

  • 部署应用程序:
    你可以使用 kubectl 部署应用程序。例如,创建一个部署:
    bash
    kubectl create deployment hello-node --image=k8s.gcr.io/echoserver:1.10

  • 暴露应用程序:
    bash
    kubectl expose deployment hello-node --type=LoadBalancer --port=8080

  • 访问应用程序:
    bash
    minikube service hello-node

    此命令会在浏览器窗口中打开你部署的应用程序。

停止和删除 Minikube

  • 停止集群:
    bash
    minikube stop

    此命令会停止 Minikube 虚拟机,但会保留其状态。

  • 删除集群:
    bash
    minikube delete

    此命令会永久删除 Minikube 虚拟机及所有相关数据。

Minikube 是一个强大的工具,可以帮助你轻松地在本地环境中使用 Kubernetes。通过遵循上述步骤,你可以快速启动并运行一个本地 Kubernetes 集群,开始你的 Kubernetes 学习和开发之旅。

滚动至顶部