Project Icon

kubectx

简化Kubernetes集群和命名空间管理的命令行工具

kubectx和kubens是用于管理Kubernetes集群上下文和命名空间的命令行工具。它们提供交互式模式、自动补全和颜色定制功能,提升kubectl使用效率。这两个工具支持多平台安装,兼容常见包管理器。kubectx和kubens简化了在不同Kubernetes环境间的切换操作,适用于需要频繁更改集群或命名空间的开发和运维工作。

kubectx + kubens: kubectl 的强大工具

最新 GitHub 发布版本 GitHub 星标数 Homebrew 下载量 Go 实现 (CI) 自豪地用 Bash 编写

本仓库提供了 kubectxkubens 两个工具。 安装 →

什么是 kubectxkubens

kubectx 是一个用于在 kubectl 上更快切换上下文(集群)的工具。
kubens 是一个用于轻松切换 Kubernetes 命名空间(并为 kubectl 配置)的工具。

这是 kubectx 的演示: kubectx 演示 GIF

...这是 kubens 的演示: kubens 演示 GIF

示例

# 切换到 kubeconfig 中的另一个集群
$ kubectx minikube
已切换到上下文 "minikube"。

# 切换回之前的集群
$ kubectx -
已切换到上下文 "oregon"。

# 重命名上下文
$ kubectx dublin=gke_ahmetb_europe-west1-b_dublin
上下文 "gke_ahmetb_europe-west1-b_dublin" 已重命名为 "dublin"。

# 更改 kubectl 的活动命名空间
$ kubens kube-system
已设置上下文 "test"。
当前命名空间是 "kube-system"。

# 返回到之前的命名空间
$ kubens -
已设置上下文 "test"。
当前命名空间是 "default"。

# 即使命名空间不存在也更改活动命名空间
$ kubens not-found-namespace --force
已设置上下文 "test"。
当前命名空间是 "not-found-namespace"。
---
$ kubens not-found-namespace -f
已设置上下文 "test"。
当前命名空间是 "not-found-namespace"。

如果您安装了 fzf,您还可以交互式地选择上下文或集群,或通过输入几个字符进行模糊搜索。要了解更多信息,请阅读交互模式 →

kubectxkubens 都支持在 bash/zsh/fish shell 上使用 Tab 补全,以帮助处理长上下文名称。您不再需要记住完整的上下文名称。


安装

kubectxkubens 的稳定版本是您可以在此仓库中找到的小型 bash 脚本。

从 v0.9.0 开始,kubectxkubens 现在用 Go 重写。它们应该以相同的方式工作(我们会保留基于 bash 的实现),但新功能将添加到新的 Go 程序中。请通过从发布页面 →下载二进制文件来帮助我们测试这个新的 Go 实现

安装选项:

如果您想在 shell 提示符($PS1)中添加上下文/命名空间信息,可以尝试使用 kube-ps1

Kubectl 插件(macOS 和 Linux)

您可以安装和使用 Krew kubectl 插件管理器来获取 kubectxkubens

注意: 这不会安装 shell 补全脚本。如果您需要它们,*请选择另一种安装方法或手动安装脚本。

kubectl krew install ctx
kubectl krew install ns

安装后,这些工具将作为 kubectl ctxkubectl ns 可用。

Homebrew(macOS 和 Linux)

如果您使用 Homebrew,可以这样安装:

brew install kubectx

此命令将自动设置 bash/zsh/fish 补全脚本。确保您配置 shell 以加载已安装的 Homebrew 公式的补全。

MacPorts(macOS)

如果您使用 MacPorts,可以这样安装:

sudo port install kubectx

apt(Debian)

sudo apt install kubectx

较新版本可能在如下仓库中可用: Debian Buster(测试版)Sid(不稳定版) (如果您不熟悉 Debian 发布过程以及如何启用测试/不稳定仓库,请查看 Debian Wiki):

pacman(Arch Linux)

可作为官方 Arch Linux 软件包安装。通过以下命令安装:

sudo pacman -S kubectx

Windows 安装 (使用 Chocolatey)

可在 Chocolatey 上作为软件包安装

choco install kubens kubectx

Windows 安装 (使用 Scoop)

可在 Scoop 上作为软件包安装

scoop bucket add main
scoop install main/kubens main/kubectx

Windows 安装 (使用 winget)

可在 winget 上作为软件包安装

winget install --id ahmetb.kubectx
winget install --id ahmetb.kubens

手动安装 (macOS 和 Linux)

由于 kubectxkubens 是用 Bash 编写的,您应该能够将它们安装到任何安装了 Bash 的 POSIX 环境中。

  • 下载 kubectxkubens 脚本。
  • 选择以下方式之一:
    • 将它们全部保存到 PATH 中的某个位置,
    • 或将它们保存到一个目录中,然后从 PATH 中的某个位置(如 /usr/local/bin)创建指向 kubectx/kubens 的符号链接
  • 使 kubectxkubens 可执行(chmod +x ...

安装步骤示例:

sudo git clone https://github.com/ahmetb/kubectx /opt/kubectx
sudo ln -s /opt/kubectx/kubectx /usr/local/bin/kubectx
sudo ln -s /opt/kubectx/kubens /usr/local/bin/kubens

如果您还想要shell补全功能,请为补全脚本选择最适合您系统的安装方法:使用 antibodyzsh普通 zshbashfish

使用 antibodyzsh 补全脚本

将此行添加到您的插件文件(例如 ~/.zsh_plugins.txt)中:

ahmetb/kubectx path:completion kind:fpath

根据您的设置,在加载插件文件后,您可能需要在 ~/.zshrc 中调用 compinitautoload -U compinit && compinit。如果您使用 oh-my-zsh,请在加载 oh-my-zsh 之前加载补全,因为 oh-my-zsh 会调用 compinit

普通 zsh 补全脚本

补全脚本必须位于属于 $fpath 的路径中。可以将它们链接或复制到现有文件夹。

使用 oh-my-zsh 的示例:

mkdir -p ~/.oh-my-zsh/custom/completions
chmod -R 755 ~/.oh-my-zsh/custom/completions
ln -s /opt/kubectx/completion/_kubectx.zsh ~/.oh-my-zsh/custom/completions/_kubectx.zsh
ln -s /opt/kubectx/completion/_kubens.zsh ~/.oh-my-zsh/custom/completions/_kubens.zsh
echo "fpath=($ZSH/custom/completions $fpath)" >> ~/.zshrc

如果补全不起作用,请将 autoload -U compinit && compinit 添加到您的 .zshrc 中(类似于 zsh-completions)。

如果您没有使用 oh-my-zsh,您可以链接到 /usr/share/zsh/functions/Completion(可能需要 sudo),具体取决于您的 zsh 安装的 $fpath

如果出现错误,调用 compaudit 可能会有所帮助。

bash 补全脚本

git clone https://github.com/ahmetb/kubectx.git ~/.kubectx
COMPDIR=$(pkg-config --variable=completionsdir bash-completion)
ln -sf ~/.kubectx/completion/kubens.bash $COMPDIR/kubens
ln -sf ~/.kubectx/completion/kubectx.bash $COMPDIR/kubectx
cat << EOF >> ~/.bashrc


#kubectx and kubens
export PATH=~/.kubectx:\$PATH
EOF

fish 补全脚本

mkdir -p ~/.config/fish/completions
ln -s /opt/kubectx/completion/kubectx.fish ~/.config/fish/completions/
ln -s /opt/kubectx/completion/kubens.fish ~/.config/fish/completions/

交互模式

如果您希望 kubectxkubens 命令为您提供带有模糊搜索的交互式菜单,只需要在您的 $PATH安装 fzf

kubectx 使用 fzf 的交互式搜索

如果您已安装 fzf,但想要退出使用此功能,请设置环境变量 KUBECTX_IGNORE_FZF=1

如果您想保留 fzf 交互模式但需要命令的默认行为,可以通过将输出管道传递给另一个命令来实现(例如 kubectx | cat )。


自定义颜色

如果您想自定义指示当前命名空间或上下文的颜色,请设置环境变量 KUBECTX_CURRENT_FGCOLORKUBECTX_CURRENT_BGCOLOR(参考此处的颜色代码):

export KUBECTX_CURRENT_FGCOLOR=$(tput setaf 6) # 蓝色文本
export KUBECTX_CURRENT_BGCOLOR=$(tput setab 7) # 白色背景

通过设置 NO_COLOR 环境变量可以禁用输出中的颜色。


如果你喜欢kubectx,你可能也会喜欢我的kubectl-aliases项目。我建议将kubectx和kubens与fzfkube-ps1搭配使用。

随时间变化的星标数

随时间变化的星标数 谷歌分析

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号