当前位置: 首页 > 工具软件 > kubectl-alias > 使用案例 >

Kubernetes系列-kubectl-安装

方飞鸣
2023-12-01

目录

1 准备工作

2 Linux 系统安装 kubectl

2.1 安装方式

2.2 使用curl命令安装

2.2.1 下载最新发行版

2.2.2 验证kubectl命令(可选)

2.2.3 安装 kubectl

2.2.4 执行测试

2.3 原生包安装

2.3.1 配置yum源

2.3.2 安装kubectl

2.3.3 验证版本

2.4 其他包管理工具安装

3 验证 kubectl 配置

4 kubectl 的可选配置和插件

4.1 Bash

4.1.1  安装 bash-completion

4.1.2 启动 kubectl 自动补全功能

4.1 Zsh


1 准备工作

kubectl 版本和集群版本之间的差异必须在一个小版本号内。 例如:v1.26 版本的客户端能与 v1.25、 v1.26 和 v1.27 版本的控制面通信。建议使用最新版本的kubectl,可避免一些不可预见的问题。

2 Linux 系统安装 kubectl

2.1 安装方式

  • 使用curl命令安装
  • 使用原生包安装
  • 使用其他包管理工具安装

2.2 使用curl命令安装

2.2.1 下载最新发行版

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

默认安装最新版本kubectl。

如需下载某个指定的版本,请用指定版本号替换该命令的这一部分: $(curl -L -s https://dl.k8s.io/release/stable.txt),如:

curl -LO https://dl.k8s.io/release/v1.26.0/bin/linux/amd64/kubectl

2.2.2 验证kubectl命令(可选)

curl -LO "https://dl.k8s.io/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl.sha256"
echo "$(cat kubectl.sha256)  kubectl" | sha256sum --check

验证通过,会输出:

kubectl: OK

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

kubectl: FAILED
sha256sum: WARNING: 1 computed checksum did NOT match

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

2.2.3 安装 kubectl

sudo install -o root -g root -m 0755 kubectl /usr/local/bin/kubectl

即使你没有目标系统的 root 权限,仍然可以将 kubectl 安装到目录 ~/.local/bin 中:

chmod +x kubectl
mkdir -p ~/.local/bin
mv ./kubectl ~/.local/bin/kubectl
# 之后将 ~/.local/bin 附加(或前置)到 $PATH

2.2.4 执行测试

此步骤的目的是验证kubectl是否为最新版。

kubectl version --client

kubectl version --client --output=yaml

2.3 原生包安装

2.3.1 配置yum源

cat <<EOF | sudo tee /etc/yum.repos.d/kubernetes.repo
[kubernetes]
name=Kubernetes
baseurl=https://packages.cloud.google.com/yum/repos/kubernetes-el7-\$basearch
enabled=1
gpgcheck=1
gpgkey=https://packages.cloud.google.com/yum/doc/rpm-package-key.gpg
EOF

2.3.2 安装kubectl

sudo yum install -y kubectl

2.3.3 验证版本

kubectl version --client

2.4 其他包管理工具安装

如果你使用 Linux 系统,并且装了 homebrew包管理工具, 则可以使用这种方式安装kubectl。

brew install kubectl
kubectl version --client

3 验证 kubectl 配置

kubectl访问 Kubernetes 集群,需要一个 kubeconfig文件,该文件在创建Kubernetes 集群时,会自动生成。 通常,kubectl 的配置信息默认存放于文件 ~/.kube/config 中。kubectl是通过解析 ~/.kube/config 文件或通过设置 KUBECONFIG 环境变量或制定--kubeconfig对Kubernetes 集群进行请求访问。

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

kubectl cluster-info

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

如果返回如下信息,则代表 kubectl 配置出了问题,或无法连接到 Kubernetes 集群。

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

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

kubectl cluster-info dump

4 kubectl 的可选配置和插件

kubectl 为 Bash、Zsh、Fish 和 PowerShell 提供自动补全功能,可以节省大量的输入。

4.1 Bash

kubectl 的 Bash 补全脚本可以用命令 kubectl completion bash 生成。 在 Shell 中导入(Sourcing)补全脚本,将启用 kubectl 自动补全功能。

然而,补全脚本依赖于工具 bash-completion, 所以要先安装 bash-completion(可以用命令 type _init_completion 检查 bash-completion 是否已安装)。

4.1.1  安装 bash-completion

很多包管理工具均支持 bash-completion。 可以通过 apt-get install bash-completion 或 yum install bash-completion 等命令来安装。

上述命令将创建文件 /usr/share/bash-completion/bash_completion,它是 bash-completion 的主脚本。 依据包管理工具的实际情况,你需要在 ~/.bashrc 文件中手工导入此文件。

重新加载Shell变量,并运行命令 type _init_completion。 如果命令执行成功,则设置完成,否则将下面内容添加到文件 ~/.bashrc 中:

source /usr/share/bash-completion/bash_completion

重新加载 Shell,再输入命令 type _init_completion 来验证 bash-completion 的安装状态。

4.1.2 启动 kubectl 自动补全功能

kubectl 补全脚本已经导入(sourced)到 Shell 会话中。 可以通过以下两种方法进行设置:​​​​​​

  • 当前用户
echo 'source <(kubectl completion bash)' >>~/.bashrc
  • 全局用户
kubectl completion bash | sudo tee /etc/bash_completion.d/kubectl > /dev/null

如果 kubectl 有关联的别名,可以扩展 Shell 补全来适配此别名:

echo 'alias k=kubectl' >>~/.bashrc
echo 'complete -o default -F __start_kubectl k' >>~/.bashrc

bash-completion 负责导入 /etc/bash_completion.d 目录中的所有补全脚本。

两种方式的效果相同。重新加载 Shell 后,kubectl 自动补全功能即可生效。 若要在当前 Shell 会话中启用 Bash 补全功能,需要运行 exec bash 命令:

exec bash

4.1 Zsh

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

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

source <(kubectl completion zsh)

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

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

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

autoload -Uz compinit

 类似资料: