【Kubernetes】多集群管理实践 - kubeconfig

Kubernetes 原生提供了 kubeconfig 文件机制,为多集群管理而设计,一起来看看如何使用吧!

  • 集群 dev:Kubernetes 1.31.19
  • 集群 prod:Kubernetes 1.35

1、理解 kubeconfig

1.1、kubeconfig 文件结构

bash 复制代码
# kubeconfig 文件包含三个主要部分:集群列表、上下文列表、用户认证信息
apiVersion: v1
kind: Config
clusters:                  # 集群列表
- name: prod-cluster
  cluster:
    server: https://api.prod.example.com
    certificate-authority-data: <base64-ca-cert>
     
contexts:                   # 上下文列表(集群+用户+命名空间)
- name: prod-admin
  context:
    cluster: prod-cluster
    user: admin-user
    namespace: default
    
current-context: prod-admin  # 当前使用的上下文

users:                       # 用户认证信息
- name: admin-user
  user:
    client-certificate-data: <base64-cert>
    client-key-data: <base64-key>

2.1、基本命令

bash 复制代码
# 查看当前配置
kubectl config view

# 查看原始配置
kubectl config view --raw

# 查看特定上下文配置
kubectl config view --context=prod-cluster

# 列出所有上下文
kubectl config get-contexts

# 切换当前上下文
kubectl config use-context prod-admin

2、使用 kubeconfig

2.1、多集群配置

  • 集群 dev:Kubernetes 1.31.19、3节点
  • 集群 prod:Kubernetes 1.35、1节点
  • 集群 config 文件位于控制节点 ~/.kube/config

2.2、安装 kubectl 命令(可选)

2.3、拷贝 config 文件

bash 复制代码
# 拷贝 prod 集群的 config 文件
scp -r root@172.16.12.36:/root/.kube/config ./config_prod
# 拷贝 dev 集群的 config 文件
scp -r root@172.16.15.105:/root/.kube/config ./config_dev

2.4、使用 config 文件连接集群

bash 复制代码
# dev 集群
kubectl --kubeconfig=config_dev get node
# prod 集群
kubectl --kubeconfig=config_prod get node

2.5、合并 config

  • 手动修改 config_dev 和 config_prod 文件
  • 修改集群名称、用户信息、上下文内容,不能使用重复名称
  • 将 config_dev 和 config_prod 合并为 config_dev_prod 文件,后续仅使用合并的文件连接 dev 和 prod 集群
bash 复制代码
# windows 环境下命令
set KUBECONFIG=config_dev;config_prod && kubectl config view --merge --flatten > config_dev_prod

# linux 环境下命令
KUBECONFIG=./config1:./config2 kubectl config view --flatten > ./configX

2.6、连接集群

bash 复制代码
# 查看上下文
kubectl --kubeconfig=config_dev_prod config get-contexts

# 查看当前上下文集群的节点
kubectl --kubeconfig=config_dev_prod get node

# 切换上下文
kubectl --kubeconfig=config_dev_prod config use-context prod

# 查看切换后上下文集群的节点
kubectl --kubeconfig=config_dev_prod get node
相关推荐
米高梅狮子15 小时前
01.CentOS-Stream-8-packstack安装OpenStack
linux·云原生·容器·kubernetes·centos·自动化·openstack
米高梅狮子17 小时前
01.mysql的备份与恢复
运维·数据库·mysql·docker·容器·kubernetes·github
云游牧者18 小时前
K8S存储体系全解-从PV-PVC-SC到StatefulSet持久化实战
云原生·容器·kubernetes·pvc·pv·sc·进阶存储卷
古城小栈18 小时前
K8s 认证、授权 系统
云原生·容器·kubernetes
码点滴18 小时前
K8s 节点“半死“状态如何自动愈合?AI Agent 构建智能自愈与健康量化体系
人工智能·容器·kubernetes
sbjdhjd19 小时前
02 下 | Kubernetes Pod 实战实验完全解析
linux·运维·云原生·kubernetes·podman·kubelet·kubeless
古城小栈20 小时前
K8s 存储组件 通俗精讲
云原生·容器·kubernetes
珂玥c20 小时前
k8s集群网络层碎碎念
云原生·容器·kubernetes
easy_coder21 小时前
Kubernetes 域名解析问题排查实战:短名为什么有时能解析,有时不行
人工智能·kubernetes·云计算
米高梅狮子1 天前
03.网络类服务实践
linux·运维·服务器·网络·kubernetes·centos·openstack