树叶云kubernetes教程:Kubernetes macOS安装

kubectl 版本和集群之间的差异必须在一个小版本号之内。 例如:v1.23 版本的客户端能与 v1.22、 v1.23 和 v1.24 版本的控制面通信。 用最新兼容版本的 kubectl 有助于避免不可预见的问题。

在 macOS 系统上安装 kubectl

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

  • 用 curl 在 macOS 系统上安装 kubectl
  • 用 Homebrew 在 macOS 系统上安装
  • 用 Macports 在 macOS 上安装
  • 作为谷歌云 SDK 的一部分,在 macOS 上安装

用 curl 在 macOS 系统上安装 kubectl 

1、下载最新的发行版:

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

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

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

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

curl -LO "https://dl.k8s.io/release/v1.23.0/bin/darwin/arm64/kubectl"

2、验证可执行文件(可选操作)

下载 kubectl 的校验和文件:

  • Intel
   curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/darwin/amd64/kubectl.sha256"
  • Apple Silicon
   curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/darwin/arm64/kubectl.sha256"
  • 根据校验和文件,验证 kubectl:
echo "$(cat kubectl.sha256)  kubectl" | shasum -a 256 --check
  • 验证通过时,输出如下:
kubectl: OK
  • 验证失败时,​shasum ​将以非零值退出,并打印如下输出:
kubectl: FAILED
shasum: WARNING: 1 computed checksum did NOT match

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

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

chmod +x ./kubectl

4、将可执行文件 kubectl 移动到系统可寻址路径 ​PATH ​内的一个位置:

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

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

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

kubectl version --client
  • 或者使用下面命令来查看版本的详细信息:
kubectl version --client --output=yaml

用 Homebrew 在 macOS 系统上安装

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

1、运行安装命令:

brew install kubectl 
brew install kubernetes-cli

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

kubectl version --client

用 Macports 在 macOS 上安装

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

1、运行安装命令:

sudo port selfupdate
sudo port install kubectl

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

kubectl version --client

验证 kubectl 配置

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

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

kubectl cluster-info

如果返回一个 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,但你还不能访问集群,那可以用以下命令来检查配置是否妥当:

kubectl cluster-info dump

可选的 kubectl 配置和插件

启用 shell 自动补全功能

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

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

Bash

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 v2 和 
Bash 4.1+。 有鉴于此,为了在 macOS 上使用 kubectl 补全功能,你必须要安装和使用 Bash 4.1+ ( 说明)。 后续说明假定你用的是 Bash 4.1+(也就是 Bash 4.1 或更新的版本)

升级 Bash

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

echo $BASH_VERSION

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

brew install bash

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

echo $BASH_VERSION $SHELL

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

安装 bash-completion 

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

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

brew install bash-completion@2

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

export BASH_COMPLETION_COMPAT_DIR="/usr/local/etc/bash_completion.d"
[[ -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)补全脚本:
echo 'source <(kubectl completion bash)' >>~/.bash_profile

  • 将补全脚本添加到目录 ​/usr/local/etc/bash_completion.d​ 中:
kubectl completion bash >/usr/local/etc/bash_completion.d/kubectl

  • 如果你为 kubectl 定义了别名,则可以扩展 shell 补全来兼容该别名:
echo 'alias k=kubectl' >>~/.bash_profile
echo 'complete -F __start_kubectl k' >>~/.bash_profile

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

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

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

Fish

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

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

kubectl completion fish | source

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

Zsh

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

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

source <(kubectl completion zsh)

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

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

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

autoload -Uz compinit
compinit

安装 kubectl convert 插件 

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

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

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

  • Apple Silicon
   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 校验和文件:

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

  • Apple Silicon
   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 的可执行文件:

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

验证通过时,输出为:

kubectl-convert: OK

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

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

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

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

chmod +x ./kubectl-convert

4、将 kubectl-convert 可执行文件移动到系统 PATH 环境变量中的一个位置。

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

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

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

kubectl convert --help

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

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/162111.html<

(0)
运维的头像运维
上一篇2025-03-18 13:07
下一篇 2025-03-18 13:08

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注