背景:
我們通過會有多個k8s集群,例如集群(cn-k8s)和集群(jp-k8s),那個就需要有一台服務器可以同時訪問兩個集群,方式:將2個集群的config信息存放到一個文件中,通過使用 kubectl config use-context
context_name 來訪問集群。簡而言之,通過設置context來讓kubectl訪問不同的k8s集群。
具體步驟如下:
假如已經准備好2個集群的配置文件,分別為 $HOME/.kube/config1 和
$HOME/.kube/config2
config1 信息如下
[root@node-01 .kube]# cat $HOME/.kube/config1 apiVersion: v1 kind: Config clusters: - cluster: api-version: v1 certificate-authority-data: xxxxxxx server: "https://172.20.8.113:6443" name: "cn-k8s" contexts: - context: cluster: "cn-k8s" user: "kube-admin-local" name: "cn-k8s" current-context: "cn-k8s" users: - name: "kube-admin-local" user: client-certificate-data: xxxxxx client-key-data: xxxxxx
config2 信息如下
[root@node-01 .kube]# cat $HOME/.kube/config2 apiVersion: v1 kind: Config clusters: - cluster: api-version: v1 certificate-authority-data: xxxxxx server: "https://172.19.8.113:6443" name: "jp-k8s" contexts: - context: cluster: "jp-k8s" user: "kube-admin-local" name: "jp-k8s" current-context: "jp-k8s" users: - name: "kube-admin-local" user: client-certificate-data: xxxxxx client-key-data: xxxxxx
通過config信息,可以看到兩個集群的cluster name,context name,以及用戶信息。
配置文件已准備好,下面開始變身了。文件合成:
cd $HOME/.kube/config
KUBECONFIG=config1:config2 kubectl config view --flatten > $HOME/.kube/config
那么如何使用呢?
1、查看cluster name以及context name
[root@node-01 ~]# kubectl config view apiVersion: v1 clusters: - cluster: certificate-authority-data: DATA+OMITTED server: https://172.19.8.113:6443 name: cnlocal - cluster: certificate-authority-data: DATA+OMITTED server: https://172.19.8.113:6443 name: jplocal contexts: - context: cluster: cnlocal user: kube-admin-local name: cnlocal - context: cluster: jplocal user: kube-admin-local name: local current-context: jplocal kind: Config preferences: {} users: - name: kube-admin-local user: client-certificate-data: REDACTED client-key-data: REDACTED
2、查看當前使用的集群
[root@node-01 ~]# kubectl config current-context jplocal
3、修改當前使用的集群
[root@node-01 ~]# kubectl config use-context cnlocal Switched to context "cnlocal".