在 Windows 上安装 kubectl
在 Windows 系统中安装 kubectl 有如下几种方法:
下载。
如果你已安装了
curl
,也可以使用此命令:说明:
要想找到最新稳定的版本(例如:为了编写脚本),可以看看这里 https://dl.k8s.io/release/stable.txt。
验证该可执行文件(可选步骤)
下载
kubectl
校验和文件:curl.exe -LO "https://dl.k8s.io/v1.27.0/bin/windows/amd64/kubectl.exe.sha256"
基于校验和文件,验证
kubectl
的可执行文件:- 在命令行环境中,手工对比
CertUtil
命令的输出与校验和文件:
CertUtil -hashfile kubectl.exe SHA256
type kubectl.exe.sha256
- 用 PowerShell 自动验证,用运算符
-eq
来直接取得True
或False
的结果:
$(Get-FileHash -Algorithm SHA256 .\kubectl.exe).Hash -eq $(Get-Content .\kubectl.exe.sha256)
将
kubectl
二进制文件夹追加或插入到你的PATH
环境变量中。测试一下,确保此
kubectl
的版本和期望版本一致:说明:
上面的命令会产生一个警告:
WARNING: This version information is deprecated and will be replaced with the output from kubectl version --short.
你可以忽略这个警告。你只检查你所安装的
kubectl
的版本。或者使用下面命令来查看版本的详细信息:
kubectl version --client --output=yaml
安装插件后,清理安装文件:
del kubectl.exe kubectl.exe.sha256
将其自带版本的 添加到 PATH
。 如果你之前安装过 Docker Desktop,可能需要把此 PATH
条目置于 Docker Desktop 安装的条目之前, 或者直接删掉 Docker Desktop 的 kubectl
。
要在 Windows 上安装 kubectl,你可以使用包管理器 、 命令行安装器 Scoop 或包管理器 。
choco install kubernetes-cli
winget install -e --id Kubernetes.kubectl
测试一下,确保安装的是最新版本:
kubectl version --client
导航到你的 home 目录:
# 当你用 cmd.exe 时,则运行: cd %USERPROFILE%
cd ~
创建目录
.kube
:mkdir .kube
切换到新创建的目录
.kube
:cd .kube
配置 kubectl,以接入远程的 Kubernetes 集群:
New-Item config -type file
说明:
编辑配置文件,你需要先选择一个文本编辑器,比如 Notepad。
为了让 kubectl 能发现并访问 Kubernetes 集群,你需要一个 kubeconfig 文件, 该文件在 创建集群时,或成功部署一个 Minikube 集群时,均会自动生成。 通常,kubectl 的配置信息存放于文件 ~/.kube/config
中。
通过获取集群状态的方法,检查是否已恰当地配置了 kubectl:
如果返回一个 URL,则意味着 kubectl 成功地访问到了你的集群。
如果你看到如下所示的消息,则代表 kubectl 配置出了问题,或无法连接到 Kubernetes 集群。
The connection to the server <server-name:port> was refused - did you specify the right host or port?
(访问 <server-name:port> 被拒绝 - 你指定的主机和端口是否有误?)
例如,如果你想在自己的笔记本上(本地)运行 Kubernetes 集群,你需要先安装一个 Minikube 这样的工具,然后再重新运行上面的命令。
如果命令 kubectl cluster-info
返回了 URL,但你还不能访问集群,那可以用以下命令来检查配置是否妥当:
下面是设置 PowerShell 自动补全功能的操作步骤。
你可以使用命令 kubectl completion powershell
生成 PowerShell 的 kubectl 自动补全脚本。
如果需要自动补全在所有 Shell 会话中生效,请将以下命令添加到 文件中:
kubectl completion powershell | Out-String | Invoke-Expression
此命令将在每次 PowerShell 启动时重新生成自动补全脚本。你还可以将生成的自动补全脚本添加到 $PROFILE
文件中。
如果需要将自动补全脚本直接添加到 $PROFILE
文件中,请在 PowerShell 命令行运行以下命令:
kubectl completion powershell >> $PROFILE
完成上述操作后重启 Shell,kubectl 的自动补全就可以工作了。
一个 Kubernetes 命令行工具 kubectl
的插件,允许你将清单在不同 API 版本间转换。 这对于将清单迁移到新的 Kubernetes 发行版上未被废弃的 API 版本时尤其有帮助。 更多信息请访问
用以下命令下载最新发行版:
curl.exe -LO "https://dl.k8s.io/release/v1.27.0/bin/windows/amd64/kubectl-convert.exe"
验证该可执行文件(可选步骤)。
下载
kubectl-convert
校验和文件:curl.exe -LO "https://dl.k8s.io/v1.27.0/bin/windows/amd64/kubectl-convert.exe.sha256"
基于校验和验证
kubectl-convert
的可执行文件:- 用提示的命令对
CertUtil
的输出和下载的校验和文件进行手动比较。
CertUtil -hashfile kubectl-convert.exe SHA256
type kubectl-convert.exe.sha256
使用 PowerShell
-eq
操作使验证自动化,获得True
或者False
的结果:$($(CertUtil -hashfile .\kubectl-convert.exe SHA256)[1] -replace " ", "") -eq $(type .\kubectl-convert.exe.sha256)
将
kubectl-convert
二进制文件夹附加或添加到你的PATH
环境变量中。验证插件是否安装成功。
如果你没有看到任何错误就代表插件安装成功了。
-
del kubectl-convert.exe kubectl-convert.exe.sha256
- 。
- 有关创建集群的更多信息,请参阅入门指南。
- 。
- 阅读 kubectl 参考文档。