在 macOS 系统上安装和设置 kubectl

    在 macOS 系统上安装 kubectl 有如下方法:

    1. 下载最新的发行版:

      1. curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/darwin/arm64/kubectl"

      Note:

      如果需要下载某个指定的版本,用该指定版本号替换掉命令的这个部分:$(curl -L -s https://dl.k8s.io/release/stable.txt)。 例如:要为 Intel macOS 系统下载 v1.23.6 版本,则输入:

      1. curl -LO "https://dl.k8s.io/release/v1.23.6/bin/darwin/amd64/kubectl"

      对于 Apple Silicon 版本的 macOS,输入:

      1. curl -LO "https://dl.k8s.io/release/v1.23.6/bin/darwin/arm64/kubectl"
    2. 验证可执行文件(可选操作)

      下载 kubectl 的校验和文件:

      1. curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/darwin/amd64/kubectl.sha256"
      1. curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/darwin/arm64/kubectl.sha256"

      根据校验和文件,验证 kubectl:

      1. echo "$(cat kubectl.sha256) kubectl" | shasum -a 256 --check

      验证通过时,输出如下:

      1. kubectl: OK

      验证失败时,shasum 将以非零值退出,并打印如下输出:

      1. shasum: WARNING: 1 computed checksum did NOT match

      Note:

      下载的 kubectl 与校验和文件版本要相同。

    3. 将 kubectl 置为可执行文件:

      1. chmod +x ./kubectl
    4. 将可执行文件 kubectl 移动到系统可寻址路径 PATH 内的一个位置:

      1. sudo mv ./kubectl /usr/local/bin/kubectl
      2. sudo chown root: /usr/local/bin/kubectl

      Note:

      确保 /usr/local/bin 在你的 PATH 环境变量中。

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

      1. kubectl version --client

      或者使用下面命令来查看版本的详细信息:

      1. kubectl version --client --output=yaml

    用 Homebrew 在 macOS 系统上安装

    如果你是 macOS 系统,且用的是 包管理工具, 则可以用 Homebrew 安装 kubectl。

    1. 运行安装命令:

      1. brew install kubectl

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

      1. kubectl version --client

    用 Macports 在 macOS 上安装

    如果你用的是 macOS,且用 包管理工具,则你可以用 Macports 安装kubectl。

    1. 运行安装命令:

      1. sudo port selfupdate
      2. sudo port install kubectl
    2. 测试一下,确保你安装的是最新的版本:

      1. kubectl version --client

    通过获取集群状态的方法,检查是否已恰当的配置了 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 为 Bash、Zsh、Fish 和 PowerShell 提供自动补全功能,可以为你节省大量的输入。

    下面是为 Bash、Fish 和 Zsh 设置自动补全功能的操作步骤。

    简介

    kubectl 的 Bash 补全脚本可以通过 kubectl completion bash 命令生成。 在你的 shell 中导入(Sourcing)这个脚本即可启用补全功能。

    此外,kubectl 补全脚本依赖于工具 bash-completion, 所以你必须先安装它。

    Warning:

    bash-completion 有两个版本:v1 和 v2。v1 对应 Bash3.2(也是 macOS 的默认安装版本),v2 对应 Bash 4.1+。 kubectl 的补全脚本无法适配 bash-completion v1 和 Bash 3.2。 必须为它配备 bash-completion v2Bash 4.1+。 有鉴于此,为了在 macOS 上使用 kubectl 补全功能,你必须要安装和使用 Bash 4.1+ ()。 后续说明假定你用的是 Bash 4.1+(也就是 Bash 4.1 或更新的版本)

    升级 Bash

    后续说明假定你已使用 Bash 4.1+。你可以运行以下命令检查 Bash 版本:

    1. echo $BASH_VERSION

    如果版本太旧,可以用 Homebrew 安装/升级:

    1. brew install bash

    重新加载 shell,并验证所需的版本已经生效:

    1. echo $BASH_VERSION $SHELL

    Homebrew 通常把它安装为 /usr/local/bin/bash

    Note:

    如前所述,本说明假定你使用的 Bash 版本为 4.1+,这意味着你要安装 bash-completion v2 (不同于 Bash 3.2 和 bash-completion v1,kubectl 的补全功能在该场景下无法工作)。

    你可以用命令 type _init_completion 测试 bash-completion v2 是否已经安装。 如未安装,用 Homebrew 来安装它:

    1. brew install bash-completion@2

    如命令的输出信息所显示的,将如下内容添加到文件 ~/.bash_profile 中:

    1. export BASH_COMPLETION_COMPAT_DIR="/usr/local/etc/bash_completion.d"
    2. [[ -r "/usr/local/etc/profile.d/bash_completion.sh" ]] && . "/usr/local/etc/profile.d/bash_completion.sh"

    重新加载 shell,并用命令 type _init_completion 验证 bash-completion v2 已经恰当的安装。

    启用 kubectl 自动补全功能

    你现在需要确保在所有的 shell 环境中均已导入(sourced) kubectl 的补全脚本, 有若干种方法可以实现这一点:

    • 在文件 ~/.bash_profile 中导入(Source)补全脚本:

      1. echo 'source <(kubectl completion bash)' >>~/.bash_profile
    • 将补全脚本添加到目录 /usr/local/etc/bash_completion.d 中:

      1. 如果你为 kubectl 定义了别名,则可以扩展 shell 补全来兼容该别名:

      2. 如果你是用 Homebrew 安装的 kubectl(如 此页面 所描述),则kubectl 补全脚本应该已经安装到目录 /usr/local/etc/bash_completion.d/kubectl 中了。这种情况下,你什么都不需要做。

        用 Hommbrew 安装的 bash-completion v2 会初始化 目录 BASH_COMPLETION_COMPAT_DIR 中的所有文件,这就是后两种方法能正常工作的原因。

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

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

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

      1. kubectl completion fish | source

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

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

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

      1. source <(kubectl completion zsh)

      如果你为 kubectl 定义了别名,kubectl 自动补全将自动使用它。

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

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

      1. autoload -Uz compinit
      2. compinit

      安装 kubectl convert 插件

      一个 Kubernetes 命令行工具 kubectl 的插件,允许你将清单在不同 API 版本间转换。 这对于将清单迁移到新的 Kubernetes 发行版上未被废弃的 API 版本时尤其有帮助。 更多信息请访问 迁移到非弃用 API

      1. 用以下命令下载最新发行版:

        1. curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/darwin/amd64/kubectl-convert"
        1. curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/darwin/arm64/kubectl-convert"
      2. 验证该可执行文件(可选步骤)

        下载 kubectl-convert 校验和文件:

        1. curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/darwin/amd64/kubectl-convert.sha256"
        1. curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/darwin/arm64/kubectl-convert.sha256"

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

        1. echo "$(cat kubectl-convert.sha256) kubectl-convert" | shasum -a 256 --check

        验证通过时,输出为:

        1. kubectl-convert: OK

        验证失败时,sha256 将以非零值退出,并打印输出类似于:

        1. kubectl-convert: FAILED
        2. shasum: WARNING: 1 computed checksum did NOT match

        Note:

        下载相同版本的可执行文件和校验和。

      3. 使 kubectl-convert 二进制文件可执行

        1. chmod +x ./kubectl-convert
      4. 将 kubectl-convert 可执行文件移动到系统 PATH 环境变量中的一个位置。

        1. sudo mv ./kubectl-convert /usr/local/bin/kubectl-convert
        2. sudo chown root: /usr/local/bin/kubectl-convert

        Note:

        确保你的 PATH 环境变量中存在 /usr/local/bin

      5. 验证插件是否安装成功

        1. kubectl convert --help

        如果你没有看到任何错误就代表插件安装成功了。