【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
相关推荐
Nice_Fold9 分钟前
Kubernetes命名空间与Pod核心概念(自用笔记)
笔记·容器·kubernetes
JellyfishMIX15 小时前
k8s 容器 cpu 概念
docker·容器·kubernetes
BIGmustang17 小时前
基于rancher-rke部署 k8s集群
容器·kubernetes·rancher
Cat_Rocky18 小时前
通过k8s实现单pod部署
java·容器·kubernetes
运维全栈笔记18 小时前
K8S部署WordPress+MySQL:模块化YAML配置详解
服务器·mysql·docker·云原生·容器·kubernetes·服务发现
眷蓝天19 小时前
k8s-pod资源对象实验
云原生·容器·kubernetes·pod资源对象
木雷坞19 小时前
Physical AI 数据工厂怎么落地?先把 CUDA、K8s、Quay 镜像拉取稳定下来
人工智能·容器·kubernetes
A-刘晨阳1 天前
K8s 之 Ingress 及 Ingress Controller
云原生·容器·kubernetes·负载均衡·ingress
亚空间仓鼠1 天前
Kubernetes技术入门与实践(三):构建高效中间件服务
中间件·容器·kubernetes
运维全栈笔记1 天前
K8S部署MySQL主从复制实现高可用数据库
mysql·adb·云原生·容器·系统架构·kubernetes·kubelet