kubecm是國內(nèi)某位大神自己寫的項目嘶朱,可以合并多個kubeconfig文件蛾坯,切換集群等。項目地址疏遏。如果你是用的bash環(huán)境脉课,需要安裝至少0.8.2版本(之前版本在bash環(huán)境下無法命令補(bǔ)全救军,聯(lián)系作者修復(fù)后的版本為0.8.2)。
此文檔環(huán)境: centos7.6 倘零、kubectl1.14.8唱遭、kubecm0.8.2
kubecm
kubecm 由 golang 編寫,支持 Mac
Linux
和 windows
平臺呈驶,delete
rename
switch
提供比較實用的交互式的操作拷泽,目前的功能包括:
- add :添加新的
kubeconfig
到$HOME/.kube/config
中 - completion :命令行自動補(bǔ)全功能
- delete:刪除已有的
context
,提供交互式和指定刪除兩種方式 - merge:將指定目錄中的
kubeconfig
合并為一個kubeconfig
文件 - rename:重名指定的
context
袖瞻,提供交互式和指定重命名兩種方式 - switch:交互式切換
context
kubeconfig文件結(jié)構(gòu)
kubeconfig
文件主要由下面幾部分構(gòu)成: 集群參數(shù)司致、用戶參數(shù)、上下文參數(shù)聋迎、當(dāng)前上下文
apiVersion: v1
clusters: #集群參數(shù)
- cluster:
certificate-authority-data:
server: https://172.16.xx.xx:6443
name: cluster1
contexts: #上下文參數(shù)
- context:
cluster: cluster1
user: admin
name: context-cluster1-admin #集群上下文名稱
current-context: context-cluster1-admin # 當(dāng)前上下文
kind: Config
preferences: {}
users: #用戶參數(shù)
- name: admin
user:
client-certificate-data:
client-key-data:
kubecm安裝
$ wget https://github.com/sunny0826/kubecm/releases/download/v0.8.2/kubecm_0.8.2_Linux_x86_64.tar.gz
$ tar -zxvf kubecm_0.8.2_Linux_x86_64.tar.gz
$ mv kubecm /usr/local/bin/
命令行自動補(bǔ)全
bash
$ source <(kubecm completion bash)
$ echo "source <(kubecm completion bash)" >> ~/.bashrc
$ source ~/.bashrc
zsh
$ source <(kubecm completion zsh)
$ echo "source <(kubecm completion zsh)" >> ~/.zshrc
$ source ~/.zshrc
kubecm使用
查看
# 查看 $HOME/.kube/config 中所有的 context
$ +------------+---------------------------+-------------+----------+--------------+
| CURRENT | NAME | CLUSTER | USER | Namespace |
+============+===========================+=============+==========+==============+
| * | context-cluster1-admin | cluster1 | admin | |
+------------+---------------------------+-------------+----------+--------------+
...
添加
# 添加 example.yaml(也可以直接用config文件) 到 $HOME/.kube/config.yaml脂矫,該方式不會覆蓋源 kubeconfig,只會在當(dāng)前目錄中生成一個 config.yaml 文件
# 我這里沒用.yaml文件砌庄。直接用的config文件
$ ls
all_config config-aliyun
$ kubecm add -f config-aliyun
generate ./config.yaml
$ ls
all_config config-aliyun config.yaml
# 功能同上羹唠,但是會將 example.yaml 中的 context 命名為 test
$ kubecm add -f config-aliyun -n test
generate ./config.yaml
# 添加 -c 會覆蓋源 kubeconfig
$ kubecm add -f config-aliyun -c
「config-aliyun」 add successful!
+------------+---------------------------+-----------------------+--------------------+--------------+
| CURRENT | NAME | CLUSTER | USER | Namespace |
+============+===========================+=======================+====================+==============+
| | config-aliyun | cluster-bh6mb7k26h | user-bh6mb7k26h | |
+------------+---------------------------+-----------------------+--------------------+--------------+
| * | context-cluster1-admin | cluster1 | admin | |
+------------+---------------------------+-----------------------+--------------------+--------------+
刪除
# 交互式刪除
$ kubecm delete
Use the arrow keys to navigate: ↓ ↑ → ← and / toggles search
Select The Delete Kube Context
?? context-cluster1-admin(*)
config-aliyun
<Exit>
--------- Info ----------
Name: context-cluster1-admin
Cluster: cluster1
User: admin
# 刪除指定context
$ kubecm delete config-aliyun
Context Delete:「config-aliyun」
合并
# 合并 all_config 目錄中的 kubeconfig,該方式不會覆蓋源 kubeconfig,只會在當(dāng)前目錄中生成一個 config.yaml 文件
$ kubecm merge -f all_config/
Loading kubeconfig file: [all_config//config-154 all_config//config-202]
Context Add: config-154
Context Add: config-202
# 添加 -c 會覆蓋源 kubeconfig
$ kubecm merge -f all_config/ -c
Loading kubeconfig file: [all_config//config-154 all_config//config-202]
Context Add: config-154
Context Add: config-202
$ kubecm
+------------+---------------+-----------------------+--------------------+--------------+
| CURRENT | NAME | CLUSTER | USER | Namespace |
+============+===============+=======================+====================+==============+
| | config-154 | cluster-8ft42c2chh | user-8ft42c2chh | |
+------------+---------------+-----------------------+--------------------+--------------+
| * | config-202 | cluster-h55g4kbd78 | user-h55g4kbd78 | |
+------------+---------------+-----------------------+--------------------+--------------+
...
重命名
# 交互式重命名
$ kubecm rename
?? Select:config-202
Rename: congig-202-1█
+------------+-----------------+-----------------------+--------------------+--------------+
| CURRENT | NAME | CLUSTER | USER | Namespace |
+============+=================+=======================+====================+==============+
| * | congig-202-1 | cluster-h55g4kbd78 | user-h55g4kbd78 | |
+------------+-----------------+-----------------------+--------------------+--------------+
| | config-154 | cluster-8ft42c2chh | user-8ft42c2chh | |
+------------+-----------------+-----------------------+--------------------+--------------+
# 將 congig-202-1 重命名為 test
$ kubecm rename -o congig-202-1 -n test
+------------+---------------+-----------------------+--------------------+--------------+
| CURRENT | NAME | CLUSTER | USER | Namespace |
+============+===============+=======================+====================+==============+
| | config-154 | cluster-8ft42c2chh | user-8ft42c2chh | |
+------------+---------------+-----------------------+--------------------+--------------+
| * | test | cluster-h55g4kbd78 | user-h55g4kbd78 | |
+------------+---------------+-----------------------+--------------------+--------------+
# 重命名當(dāng)前current-context 為 dev
$ kubecm rename -n dev -c
Rename test to dev
+------------+---------------+-----------------------+--------------------+--------------+
| CURRENT | NAME | CLUSTER | USER | Namespace |
+============+===============+=======================+====================+==============+
| | config-154 | cluster-8ft42c2chh | user-8ft42c2chh | |
+------------+---------------+-----------------------+--------------------+--------------+
| * | dev | cluster-h55g4kbd78 | user-h55g4kbd78 | |
+------------+---------------+-----------------------+--------------------+--------------+
切換
# 集群切換
$ kubecm switch
Use the arrow keys to navigate: ↓ ↑ → ← and / toggles search
Select Kube Context
?? config-154(*)
dev
<Exit>
--------- Info ----------
Name: config-154
Cluster: cluster-8ft42c2chh
User: user-8ft42c2chh
# 切換命名空間
$ kubecm ns
Use the arrow keys to navigate: ↓ ↑ → ← and / toggles search
Select Namespace:
↑ ?? default *
demo
dev
↓ exdns