--- title: 在 Linux 系统中安装并设置 kubectl content_type: task weight: 10 card: name: tasks weight: 20 title: 在 Linux 系统中安装 kubectl --- ## {{% heading "prerequisites" %}} kubectl 版本和集群版本之间的差异必须在一个小版本号内。 例如:v{{< skew currentVersion >}} 版本的客户端能与 v{{< skew currentVersionAddMinor -1 >}}、 v{{< skew currentVersionAddMinor 0 >}} 和 v{{< skew currentVersionAddMinor 1 >}} 版本的控制面通信。 用最新兼容版的 kubectl 有助于避免不可预见的问题。 ## 在 Linux 系统中安装 kubectl {#install-kubectl-on-linux} 在 Linux 系统中安装 kubectl 有如下几种方法: - [用 curl 在 Linux 系统中安装 kubectl](#install-kubectl-binary-with-curl-on-linux) - [用原生包管理工具安装](#install-using-native-package-management) - [用其他包管理工具安装](#install-using-other-package-management) ### 用 curl 在 Linux 系统中安装 kubectl {#install-kubectl-binary-with-curl-on-linux} 1. 用以下命令下载最新发行版: ```bash curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl" ``` {{< note >}} 如需下载某个指定的版本,请用指定版本号替换该命令的这一部分: `$(curl -L -s https://dl.k8s.io/release/stable.txt)`。 例如,要在 Linux 中下载 {{< param "fullversion" >}} 版本,请输入: ```bash curl -LO https://dl.k8s.io/release/{{< param "fullversion" >}}/bin/linux/amd64/kubectl ``` {{< /note >}} 2. 验证该可执行文件(可选步骤) 下载 kubectl 校验和文件: ```bash curl -LO "https://dl.k8s.io/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl.sha256" ``` 基于校验和文件,验证 kubectl 的可执行文件: ```bash echo "$( 验证通过时,输出为: ```console kubectl: OK ``` 验证失败时,`sha256` 将以非零值退出,并打印如下输出: ```bash kubectl: FAILED sha256sum: WARNING: 1 computed checksum did NOT match ``` {{< note >}} 下载的 kubectl 与校验和文件版本必须相同。 {{< /note >}} 3. 安装 kubectl ```bash sudo install -o root -g root -m 0755 kubectl /usr/local/bin/kubectl ``` {{< note >}} 即使你没有目标系统的 root 权限,仍然可以将 kubectl 安装到目录 `~/.local/bin` 中: ```bash chmod +x kubectl mkdir -p ~/.local/bin/kubectl mv ./kubectl ~/.local/bin/kubectl # 之后将 ~/.local/bin/kubectl 添加到 $PATH ``` {{< /note >}} 4. 执行测试,以保障你安装的版本是最新的: ```bash kubectl version --client ``` ### 用原生包管理工具安装 {#install-using-native-package-management} {{< tabs name="kubectl_install" >}} {{% tab name="Ubuntu、Debian 或 HypriotOS" %}} 1. 更新 `apt` 包索引,并安装使用 Kubernetes `apt` 仓库所需要的包: ```shell sudo apt-get update sudo apt-get install -y apt-transport-https ca-certificates curl ``` 2. 下载 Google Cloud 公开签名秘钥: ```shell sudo curl -fsSLo /usr/share/keyrings/kubernetes-archive-keyring.gpg https://packages.cloud.google.com/apt/doc/apt-key.gpg ``` 3. 添加 Kubernetes `apt` 仓库: ```shell echo "deb [signed-by=/usr/share/keyrings/kubernetes-archive-keyring.gpg] https://apt.kubernetes.io/ kubernetes-xenial main" | sudo tee /etc/apt/sources.list.d/kubernetes.list ``` 4. 更新 `apt` 包索引,使之包含新的仓库并安装 kubectl: ```shell sudo apt-get update sudo apt-get install -y kubectl ``` {{% /tab %}} {{% tab name="基于 Red Hat 的发行版" %}} ```shell cat <}} ### 用其他包管理工具安装 {#install-using-other-package-management} {{< tabs name="other_kubectl_install" >}} {{% tab name="Snap" %}} 如果你使用的 Ubuntu 或其他 Linux 发行版,内建支持 [snap](https://snapcraft.io/docs/core/install) 包管理工具, 则可用 [snap](https://snapcraft.io/) 命令安装 kubectl。 ```shell snap install kubectl --classic kubectl version --client ``` {{% /tab %}} {{% tab name="Homebrew" %}} 如果你使用 Linux 系统,并且装了 [Homebrew](https://docs.brew.sh/Homebrew-on-Linux) 包管理工具, 则可以使用这种方式[安装](https://docs.brew.sh/Homebrew-on-Linux#install) kubectl。 ```shell brew install kubectl kubectl version --client ``` {{% /tab %}} {{< /tabs >}} ## 验证 kubectl 配置 {#verify-kubectl-configration} {{< include "included/verify-kubectl.md" >}} ## kubectl 的可选配置和插件 {#optional-kubectl-configurations} ### 启用 shell 自动补全功能 {#enable-shell-autocompletion} kubectl 为 Bash、Zsh、Fish 和 PowerShell 提供自动补全功能,可以为你节省大量的输入。 下面是为 Bash、Fish 和 Zsh 设置自动补全功能的操作步骤。 {{< tabs name="kubectl_autocompletion" >}} {{< tab name="Bash" include="included/optional-kubectl-configs-bash-linux.md" />}} {{< tab name="Fish" include="included/optional-kubectl-configs-fish.md" />}} {{< tab name="Zsh" include="included/optional-kubectl-configs-zsh.md" />}} {{< /tabs >}} ### 安装 `kubectl convert` 插件 {{< include "included/kubectl-convert-overview.md" >}} 1. 用以下命令下载最新发行版: ```bash curl -LO https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl-convert ``` 2. 验证该可执行文件(可选步骤) 下载 kubectl-convert 校验和文件: ```bash curl -LO "https://dl.k8s.io/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl-convert.sha256" ``` 基于校验和,验证 kubectl-convert 的可执行文件: ```bash echo "$( 验证通过时,输出为: ```console kubectl-convert: OK ``` 验证失败时,`sha256` 将以非零值退出,并打印输出类似于: ```bash kubectl-convert: FAILED sha256sum: WARNING: 1 computed checksum did NOT match ``` {{< note >}} 下载相同版本的可执行文件和校验和。 {{< /note >}} 3. 安装 kubectl-convert ```bash sudo install -o root -g root -m 0755 kubectl-convert /usr/local/bin/kubectl-convert ``` 4. 验证插件是否安装成功 ```shell kubectl convert --help ``` 如果你没有看到任何错误就代表插件安装成功了。 ## {{% heading "whatsnext" %}} {{< include "included/kubectl-whats-next.md" >}}