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".