在 Windows 上安装 kubectl

准备开始

kubectl 版本和集群版本之间的差异必须在一个小版本号内。 例如:v1.2 版本的客户端只能与 v1.1、v1.2 和 v1.3 版本的集群一起工作。 用最新版的 kubectl 有助于避免不可预见的问题。

在 Windows 上安装 kubectl

在 Windows 系统中安装 kubectl 有如下几种方法:

用 curl 在 Windows 上安装 kubectl

  1. 下载 最新发行版 v1.21.0

    如果你已安装了 curl,也可以使用此命令:

    1. curl -LO https://dl.k8s.io/release/v1.21.0/bin/windows/amd64/kubectl.exe

    说明: 要想找到最新稳定的版本(例如:为了编写脚本),可以看看这里 https://dl.k8s.io/release/stable.txt

  2. 验证该可执行文件(可选步骤)

    下载 kubectl 校验和文件:

    1. curl -LO https://dl.k8s.io/v1.21.0/bin/windows/amd64/kubectl.exe.sha256

    基于校验和文件,验证 kubectl 的可执行文件:

    • 在命令行环境中,手工对比 CertUtil 命令的输出与校验和文件:

      1. CertUtil -hashfile kubectl.exe SHA256
      2. type kubectl.exe.sha256
    • 用 PowerShell 自动验证,用运算符 -eq 来直接取得 TrueFalse 的结果:

      1. $($(CertUtil -hashfile .\kubectl.exe SHA256)[1] -replace " ", "") -eq $(type .\kubectl.exe.sha256)
  3. 将可执行文件的路径添加到 PATH

  4. 测试一下,确保此 kubectl 的版本和期望版本一致:

    1. kubectl version --client

说明: Windows 版的 Docker Desktop 将其自带版本的 kubectl 添加到 PATH。 如果你之前安装过 Docker Desktop,可能需要把此 PATH 条目置于 Docker Desktop 安装的条目之前, 或者直接删掉 Docker Desktop 的 kubectl

用 PowerShell 从 PSGallery 安装

如果你工作在 Windows 平台上,且使用 PowerShell Gallery 包管理器, 则可以用 PowerShell 安装、更新 kubectl。

  1. 运行安装命令(确保提供了参数 DownloadLocation):

    1. Install-Script -Name 'install-kubectl' -Scope CurrentUser -Force
    2. install-kubectl.ps1 [-DownloadLocation <path>]

    说明: 如果没有指定 DownloadLocationkubectl 则会被安装到用户的 temp 目录下。

    安装程序创建 $HOME/.kube,并指示其创建配置文件。

  2. 测试一下,确保你安装的是最新版本:

    1. kubectl version --client

说明: 更新安装是通过重新运行步骤 1 中的两个命令而实现。

在 Windows 上用 Chocolatey 或 Scoop 安装

  1. 要在 Windows 上安装 kubectl,你可以使用包管理器 Chocolatey 或是命令行安装器 Scoop

    1. choco install kubernetes-cli
    1. scoop install kubectl
  2. 测试一下,确保安装的是最新版本:

    1. kubectl version --client
  3. 导航到你的 home 目录:

    1. # 当你用 cmd.exe 时,则运行: cd %USERPROFILE%
    2. cd ~
  4. 创建目录 .kube

    1. mkdir .kube
  5. 切换到新创建的目录 .kube

    1. cd .kube
  6. 配置 kubectl,以接入远程的 Kubernetes 集群:

    1. New-Item config -type file

说明: 编辑配置文件,你需要先选择一个文本编辑器,比如 Notepad。

作为谷歌云 SDK 的一部分,在 Windows 上安装

kubectl 可以作为 Google Cloud SDK 的一部分被安装。

  1. 安装 Google Cloud SDK

  2. 运行安装 kubectl 的命令:

    1. gcloud components install kubectl
  3. 验证一下,确保安装的是最新的版本:

    1. kubectl version --client

验证 kubectl 配置

为了让 kubectl 能发现并访问 Kubernetes 集群,你需要一个 kubeconfig 文件, 该文件在 kube-up.sh 创建集群时,或成功部署一个 Miniube 集群时,均会自动生成。 通常,kubectl 的配置信息存放于文件 ~/.kube/config 中。

通过获取集群状态的方法,检查是否已恰当的配置了 kubectl:

  1. kubectl cluster-info

如果返回一个 URL,则意味着 kubectl 成功的访问到了你的集群。

如果你看到如下所示的消息,则代表 kubectl 配置出了问题,或无法连接到 Kubernetes 集群。

  1. The connection to the server <server-name:port> was refused - did you specify the right host or port?
  2. (访问 <server-name:port> 被拒绝 - 你指定的主机和端口是否有误?)

例如,如果你想在自己的笔记本上(本地)运行 Kubernetes 集群,你需要先安装一个 Minikube 这样的工具,然后再重新运行上面的命令。

如果命令 kubectl cluster-info 返回了 url,但你还不能访问集群,那可以用以下命令来检查配置是否妥当:

  1. kubectl cluster-info dump

kubectl 可选配置

启用 shell 自动补全功能

kubectl 为 Bash 和 Zsh 提供自动补全功能,可以减轻许多输入的负担。

下面是设置 Zsh 自动补全功能的操作步骤,前提是你在 Windows 上面运行的是 Zsh。

kubectl 通过命令 kubectl completion zsh 生成 Zsh 自动补全脚本。 在 shell 中导入(Sourcing)该自动补全脚本,将启动 kubectl 自动补全功能。

为了在所有的 shell 会话中实现此功能,请将下面内容加入到文件 ~/.zshrc 中。

  1. source <(kubectl completion zsh)

如果你为 kubectl 定义了别名,可以扩展脚本补全,以兼容该别名。

  1. echo 'alias k=kubectl' >>~/.zshrc
  2. echo 'complete -F __start_kubectl k' >>~/.zshrc

重新加载 shell 后,kubectl 自动补全功能将立即生效。

如果你收到 complete:13: command not found: compdef 这样的错误提示,那请将下面内容添加到 ~/.zshrc 文件的开头:

  1. autoload -Uz compinit
  2. compinit

接下来