引言
最近买了台新电脑,之前的电脑上面k8s多集群访问配置方式现在忘了当时是怎么配置了,于是自己再次摸索配置成功,记录下来分享给大家。
注意:本人电脑是Mac,接下来的操作默认是在Mac上面的zshell上面执行。
操作
1、首先安装docker和kubectl
docker安装点击这里,下载即可安装。
➜ ~ docker -v
Docker version 20.10.23, build 7155243
kubectl安装点击这里
➜ ~ kubectl version
WARNING: This version information is deprecated and will be replaced with the output from kubectl version --short. Use --output=yaml|json to get the full version.
Client Version: version.Info{Major:"1", Minor:"26", GitVersion:"v1.26.2", GitCommit:"fc04e732bb3e7198d2fa44efa5457c7c6f8c0f5b", GitTreeState:"clean", BuildDate:"2023-02-22T13:32:21Z", GoVersion:"go1.20.1", Compiler:"gc", Platform:"darwin/arm64"}
Kustomize Version: v4.5.7
Server Version: version.Info{Major:"1", Minor:"24+", GitVersion:"v1.24.6-aliyun.1", GitCommit:"e0e067a81f9fa91d46792937d79ec41ec79762eb", GitTreeState:"clean", BuildDate:"2023-02-28T12:15:08Z", GoVersion:"go1.18.6", Compiler:"gc", Platform:"linux/amd64"}
WARNING: version difference between client (1.26) and server (1.24) exceeds the supported minor version skew of +/-1
2、启用k8s
安装好docker和kubectl之后,我们打开docker GUI,如下所示:
设置k8s为启用状态,这时候你会发现用户目录下会多出.kube
目录,我们到.kube目录下可以看到里面有config
文件
➜ .kube ll
total 72
drwxr-x---@ 4 justinzhang staff 128B 3 22 15:37 cache
-rw-r--r--@ 1 justinzhang wheel 13K 4 1 17:03 config
我们可以打开config
文件看看里面的内容
apiVersion: v1
clusters:
- cluster:
certificate-authority-data: xxx
server: https://kubernetes.docker.internal:6443
name: docker-desktop
contexts:
- context:
cluster: docker-desktop
user: docker-desktop
name: docker-desktop
current-context: docker-desktop
kind: Config
preferences: {}
users:
- name: docker-desktop
user:
client-certificate-data: xxx
client-key-data: xxx
我们会发现里面默认已经有了一个叫docker-desktop
的集群。
2、配置k8s多集群
我们现在已经有了一个叫docker-desktop
,那么我们如何配置第2个集群的config
文件呢?
我们可以这样做:
2.1、备份config文件
cp ~/.kube/config ~/.kube/config.bak
2.2、将2份k8s config 文件合并成一份
KUBECONFIG=~/.kube/conifg:~/your-second-k8s-config-path/config kubectl config view -- flattern > /tmp/config
说明:上面的your-second-k8s-config-path
是你的第2个k8s集群config
文件所在目录。
2.3、将合并好的/tmp/config
文件替换成默认的config
文件
mv /tmp/config ~/.kube/config
2.4、配置默认集群
默认情况下,默认集群是是docker-desktop
,对应的是current-context
属性,所以这里只要执行kubectl config use-context
命令改成你第2个k8s集群名称即可,如下所示。
kubectl config use-context your-second-cluster-name
这样就完成了所有配置,后面也可以通过上面命令非常方便的切换到你想要的k8s集群,非常方便。
现在你可以通过kubectl命令查看第2个集群里面的内容了,如下所示:
➜ kubectl get po -nseaurl
NAME READY STATUS RESTARTS AGE
test-seaurl-webapp-79996476f9-8q2sc 1/1 Running 0 6h42m
testapi-seaurl-account-service-748887ddc4-82rtw 1/1 Running 0 123d
testapi-seaurl-auth-service-754c5b4449-mw9jj 1/1 Running 0 123d
testapi-seaurl-gatewayserver-64488b6f58-hngbk 1/1 Running 0 123d
testapi-seaurl-message-service-6fb5c4f5cb-2jj59 1/1 Running 0 123d
testapi-seaurl-notify-service-5776846f6d-sqdjb 1/1 Running 0 90d
testapi-seaurl-space-service-5d6b5dc4ff-lhqv4 1/1 Running 0 12d
testapi-seaurl-users-service-7b7b6575d7-tnf4g 1/1 Running 0 3d23h
总结
1、合并k8s
的集群config
文件网上有好多方法,感觉这种是最简单了吧
引用
解决docker kubernetes一直处于starting状态问题
快速合并2个kubectl config 文件
配置对多集群的访问
自动合并Kubeconfig,实现多k8s集群切换
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。