应用背景

项目通常有多个 k8s 集群环境,dev、testing、staging、prod,kubetcl 在多个环境中切换,操作集群 Pod 等资源对象,前提条件是将这三个环境的配置信息都写到本地机或是K8S外部一台管理机器的 $HOME/.kube/config 文件中。

本文将介绍如何通过将多个kubeconfig文件合并为一个来配置多集群的访问,从而进行K8S多集群统一管理。

默认情况下 kubectl 会查找 $HOME/.kube 目录中命名为 config 的文件。那么,我们如何将多个 kubeconfig 文件合并为一个呢?

以下是步骤:

操作步骤

备份config文件

cp $HOME/.kube/config $HOME/.kube/config-backup

设置KUBECONFIG环境变量

KUBECONFIG 环境变量是配置文件的路径列表,例如/path/cluster1:/path/cluster2:/path/cluster3

export KUBECONFIG=$HOME/.kube/config:/path/cluster1:/path/cluster2

如果当前目录下有很多 kubeconfig 文件,可以使用以下命令快速设置KUBECONFIG 环境变量。

$ cd $HOME/.kube
$ ls $HOME/.kube
config-dev config-testing config-staging config-prod

$ export KUBECONFIG=$HOME/.kube/config:$(find $HOME/.kube -type f -maxdepth 1 | grep config | tr '\n' ':')

将所有 kubeconfig 文件合并为一个

kubectl config view --flatten > all-in-one-kubeconfig.yaml

验证它是否有效

显示在 kubeconfig 中定义的所有集群:

kubectl config get-contexts --kubeconfig=$HOME/.kube/all-in-one-kubeconfig.yaml

通过--kubeconfig参数指定刚生成的 all in one 配置文件,就会根据该文件内配置的集群信息去获取所有集群的上下文。

用新合并的配置文件替换旧配置文件

mv all-in-one-kubeconfig.yaml $HOME/.kube/config

替换旧配置文件,将包含有多集群信息的配置文件作为默认配置文件,我们就可以通过 kubectl config use-contexts的指令去切换不同的集群上下文 

总结

值得一提的事,其他快捷工具还有 kubectx,它可以比 kubectl 更快地在上下文(集群)之间切换,但还是依赖于 config 的合并。

https://github.com/ahmetb/kubectx

也可以使用国人开源的 ki命令行工具,不用合并 config,直接使用ki -s即可快速完成切换。

https://github.com/ywgx/ki

参考资料

配置对多集群的访问

如何将多个 kubeconfig 文件合并为一个?

Logo

K8S/Kubernetes社区为您提供最前沿的新闻资讯和知识内容

更多推荐