kubectl多集群配置

Kubectl 是一个命令行接口,用于对 Kubernetes 集群运行命令。默认Kubectl 会读取 $HOME/.kube/config 的文件。也可以通过设置环境变量 KUBECONFIG 或设置 –kubeconfig 参数指定其它 kubeconfig 文件。

一、单集群配置

在单集群下配置非常简单:

mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
也可以通过环境变量配置
export KUBECONFIG=/etc/kubernetes/admin.conf

二、多集群配置

1.别名方式

这个是我喜欢使用的一种方式,非常方便进行切换,只需要将如下信息放到$HOME/.bashrc文件中:

alias brazil='export KUBECONFIG=/root/brazil.json'
alias chile='export KUBECONFIG=/root/chile.json'
alias mcp='export KUBECONFIG=/root/mcp.json'

2.kubectl参数增加

kubectl --kubeconfig=/root/mcp.json get endpoints
kubectl --kubeconfig=/root/brazil.json get delpoyments

这种方式和 export KUBECONFIG=file 的方式实际并没有太大区别。

3.集群config文件合并

同样需要新建.kube文件夹,拷贝不同集群的config,例如重命名为config-jhmy和config-ymt,分别查看配置文件。

[root@jenkins .kube]# cat config-jhmy
apiVersion: v1
clusters:
- cluster:
    certificate-authority-data: LS0tLS1CRUdJTiBDRVJUSU******
    server: https://10.88.88.147:6443
  name: kubernetes
contexts:
- context:
    cluster: kubernetes
    user: kubernetes-admin
  name: kubernetes-admin@kubernetes
current-context: kubernetes-admin@kubernetes
kind: Config
preferences: {}
users:
- name: kubernetes-admin
  user:
    client-certificate-data: LS0tLS1CRUdJTiBDRVJUSUZ******
    client-key-data: LS0tLS1CRUdJTiBSU0E******

两份配置文件中context、cluster、users名称必须不一样(同集群设置不同环境除外),否则调用将会出错,所以我们可以适当修改配置文件。然后执行以下命令生成新的config文件即可:

[root@jenkins .kube]# KUBECONFIG=config-ymt:config-jhmy kubectl config view --flatten > $HOME/.kube/config

使用的时候,可以通过如下方式切换:

[root@jenkins .kube]# kubectl config current-context
k8s-jhmy
[root@jenkins .kube]# kubectl get nodes
[root@jenkins .kube]# kubectl config use-context k8s-ymt
Switched to context "k8s-ymt".

发表回复

您的电子邮箱地址不会被公开。