k8s中kubeconfig的配置以及使用详解

本文详细介绍了 Kubernetes 中 kubeconfig 文件的配置方法及使用技巧,包括如何设置集群、用户信息及上下文,帮助读者掌握 kubeconfig 的核心概念和操作流程。

概述

kubeconfig 文件保存了 k8s 集群的集群、用户、命名空间、认证的信息。kubectl 命令使用 kubeconfig 文件来获取集群的信息,然后和API server进行通讯。

注意:用于配置对集群的访问的文件称为 kubecconfig 文件。也就是说,kubeconfig 文件中包含的内容是集群的配置。但是,并不是必须有个文件名字叫 kubeconfig

默认情况下,kubectl命令从 $HOME/.kube 目录下查找一个名字叫做 config 的文件。可以通过 KUBECONFIG 环境变量或者–kubeconfig 参数来指定其他的 kubeconfig 文件。

kubeconfig中主要由如下部分组成:

  • clusters (集群)

  • users(用户)

  • context(上下文)


kubeconfig支持多集群、多用户、多认证

在实际的使用中的如下场景:

  • kubelet使用证书认证(kubelet和api server进行认证)

  • 用户使用token进行认证

  • 管理员为不同的用户提供不同的证书

都可以使用kubeconfig来组织起集群、用户、命名空间的信息。同样,也可以使用context在集群和命名空间之间进行切换。


Context的定义

在kubeconfig中,context中将访问一个集群的参数进行分组。访问这个context名称就是访问这个参数组。context就是一组信息的别名,举例:当在高德中使用家的地址,公司的地址就是一个别名,就能迅速的定位到具体的地址信息。

每个context都有3个参数:

  • cluster (集群)
  • namespace(命名空间)
  • user(用户)

默认情况下,kubectl命令从current context中来获取参数,然后与集群进行通讯。


查看kubeconfig的配置

如果有KUBECONFIG环境变量,看到的配置是合并的配置

[root@nccztsjb-node-11 ~]# kubectl config view
apiVersion: v1
clusters:
- cluster:
    certificate-authority-data: DATA+OMITTED
    server: https://k8s.apiserver.io:6443
  name: cluster.local
contexts:
- context:
    cluster: cluster.local
    user: kubernetes-admin-cluster.local
  name: kubernetes-admin-cluster.local@cluster.local
current-context: kubernetes-admin-cluster.local@cluster.local
kind: Config
preferences: {}
users:
- name: kubernetes-admin-cluster.local
  user:
    client-certificate-data: REDACTED
    client-key-data: REDACTED
[root@nccztsjb-node-11 ~]# 

通过kubectl config view得到的配置可能是来自一个kubeconfig文件,也可能是来自多个kubeconfig文件合并的结果。


kubeconfig设置

设置集群

(1)集群有CA认证,并且将证书的输入嵌入到配置文件中

kubectl config --kubeconfig=config-demo set-cluster development --server=https://1.2.3.4 --embed-certs --certificate-authority=ca.crt

指定–kubeconfig参数后,所有的配置都会写到对应的文件中。如果不指定–kubeconfig参数那么就会将配置文件写到~/.kube/config这个文件中。

–certificate-authority后面是ca证书的路径,需要确保这个证书是存在的。

查看config-demo文件的内容

[root@nccztsjb-node-11 config-exercise]# cat config-demo 
apiVersion: v1
clusters:
- cluster:
    certificate-authority-data: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUM2VENDQWRHZ0F3SUJBZ0lCQURBTkJna3Foa2lHOXcwQkFRc0ZBREFWTVJNd0VRWURWUVFERXdwcmRXSmwKY201bGRHVnpNQ0FYRFRJeE1USXdNakE0TURjMU5sb1lEekl4TVRFeE1URXhNRGd3TnpVMldqQVZNUk13RVFZRApWUVFERXdwcmRXSmxjbTVsZEdWek1JSUJJakFOQmdrcWhraUc5dzBCQVFFRkFBT0NBUThBTUlJQkNnS0NBUUVBCnFaWkVNZDhORHpoek5hTE1ab2tCenlabVUzQWh6R1Z4OW15MzJxaTB3UzkzS3Jib0xMUWhSSUhCYnYzdzZCbCsKZlBYaUdSeCt4OVpKY2lta1BqdmJtQ0ZpKzEvQmsxZkFONlNBSi9ISjJoenQxcExZbW41NXVVclpqdmFCTXNUdAp5U3B4QUlOUWNNU1NJYUFyeHF1VDJ0QjYzWkMvTHloQVFWWG4xL2lYS3hLTmpidjVlS21BdlRRTlQrNlMxaFIxCkJNQXNjSFc0R1lhNXVBTFZBTmZrVlpGaG5GMmt2cVMyRzRDMXV4emZtOFpyUnREOExRUjFmTnk1VnpnVkJLQjMKT2RKQkExNnl4YXk5N2JjaEtqenpqTmxKMFBlVDBOdFZZWVRlZ3F1ZG5iRURRSEdObC91Ym5UcGtWWHpFUGRKNAo3a3FQREdWUzRXYi9DZXpVcm9IQ1hRSURBUUFCbzBJd1FEQU9CZ05WSFE4QkFmOEVCQU1DQXFRd0R3WURWUjBUCkFRSC9CQVV3QXdFQi96QWRCZ05WSFE0RUZnUVVmQldoK3hIdlVSdFdKdUVuUUlYTHRDUzh2MEl3RFFZSktvWkkKaHZjTkFRRUxCUUFEZ2dFQkFHeHNvSXJOZkJYRkp1RjZwYmtvSkh3eVdCSkp0Qzlud1VabWNCMmYzT0xTZTN4LwpQQU5oYm9LcHZ6ME5ocm5IQ2VnUk1rWGlmSmhKZW9VU25sYUhJaWpjVlFDZ09sTDVnT0EyeFZkRk01MlZCTk5jCnN1Qmp2MHJoQnZXMWxaYWVEUGJuaGp3dGY5elp2WG4vMUkvZ1RKSVRiNmFVdk55b1U3WHY2c3RmN1NjaExwU3kKZmVwRjNKRFc5TXRvem9yMHhoV0U3M0FrZHE1bnE4OFlSdEcxK3UwRTJXbDJ5U20yR0dzRUkvcU1HOXlvd0NsRgozSnhOQm45MEk3V0xKd0pETGZZMXYwWXdRNDR3QUJteGN4R01qVzNmOHAvL3pxSHNaaXJGdTR3QUlUK003Mmw3CkhDbXAwbm84VXpKMUdMUFcxNzF5TWNsdlJNM3h2SENtZHd0VktBMD0KLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQo=
    server: https://1.2.3.4
  name: development
contexts: null
current-context: ""
kind: Config
preferences: {}
users: null
[root@nccztsjb-node-11 config-exercise]# 

已经设置好了集群

(2)集群没有证书的

kubectl config --kubeconfig=config-demo set-cluster development --server=https://1.2.3.4

查看证书内容

[root@nccztsjb-node-11 config-exercise]# kubectl config --kubeconfig=config-demo set-cluster development --server=https://1.2.3.4
Cluster "development" set.
[root@nccztsjb-node-11 config-exercise]# cat config-demo 
apiVersion: v1
clusters:
- cluster:
    server: https://1.2.3.4
  name: development
contexts: null
current-context: ""
kind: Config
preferences: {}
users: null
[root@nccztsjb-node-11 config-exercise]

(3)集群有证书,但是证书验证的

kubectl config --kubeconfig=config-demo set-cluster scratch --server=https://5.6.7.8 --insecure-skip-tls-verify

查看证书的内容

[root@nccztsjb-node-11 config-exercise]# cat config-demo 
apiVersion: v1
clusters:
- cluster:
    certificate-authority-data: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUM2VENDQWRHZ0F3SUJBZ0lCQURBTkJna3Foa2lHOXcwQkFRc0ZBREFWTVJNd0VRWURWUVFERXdwcmRXSmwKY201bGRHVnpNQ0FYRFRJeE1USXdNakE0TURjMU5sb1lEekl4TVRFeE1URXhNRGd3TnpVMldqQVZNUk13RVFZRApWUVFERXdwcmRXSmxjbTVsZEdWek1JSUJJakFOQmdrcWhraUc5dzBCQVFFRkFBT0NBUThBTUlJQkNnS0NBUUVBCnFaWkVNZDhORHpoek5hTE1ab2tCenlabVUzQWh6R1Z4OW15MzJxaTB3UzkzS3Jib0xMUWhSSUhCYnYzdzZCbCsKZlBYaUdSeCt4OVpKY2lta1BqdmJtQ0ZpKzEvQmsxZkFONlNBSi9ISjJoenQxcExZbW41NXVVclpqdmFCTXNUdAp5U3B4QUlOUWNNU1NJYUFyeHF1VDJ0QjYzWkMvTHloQVFWWG4xL2lYS3hLTmpidjVlS21BdlRRTlQrNlMxaFIxCkJNQXNjSFc0R1lhNXVBTFZBTmZrVlpGaG5GMmt2cVMyRzRDMXV4emZtOFpyUnREOExRUjFmTnk1VnpnVkJLQjMKT2RKQkExNnl4YXk5N2JjaEtqenpqTmxKMFBlVDBOdFZZWVRlZ3F1ZG5iRURRSEdObC91Ym5UcGtWWHpFUGRKNAo3a3FQREdWUzRXYi9DZXpVcm9IQ1hRSURBUUFCbzBJd1FEQU9CZ05WSFE4QkFmOEVCQU1DQXFRd0R3WURWUjBUCkFRSC9CQVV3QXdFQi96QWRCZ05WSFE0RUZnUVVmQldoK3hIdlVSdFdKdUVuUUlYTHRDUzh2MEl3RFFZSktvWkkKaHZjTkFRRUxCUUFEZ2dFQkFHeHNvSXJOZkJYRkp1RjZwYmtvSkh3eVdCSkp0Qzlud1VabWNCMmYzT0xTZTN4LwpQQU5oYm9LcHZ6ME5ocm5IQ2VnUk1rWGlmSmhKZW9VU25sYUhJaWpjVlFDZ09sTDVnT0EyeFZkRk01MlZCTk5jCnN1Qmp2MHJoQnZXMWxaYWVEUGJuaGp3dGY5elp2WG4vMUkvZ1RKSVRiNmFVdk55b1U3WHY2c3RmN1NjaExwU3kKZmVwRjNKRFc5TXRvem9yMHhoV0U3M0FrZHE1bnE4OFlSdEcxK3UwRTJXbDJ5U20yR0dzRUkvcU1HOXlvd0NsRgozSnhOQm45MEk3V0xKd0pETGZZMXYwWXdRNDR3QUJteGN4R01qVzNmOHAvL3pxSHNaaXJGdTR3QUlUK003Mmw3CkhDbXAwbm84VXpKMUdMUFcxNzF5TWNsdlJNM3h2SENtZHd0VktBMD0KLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQo=
    server: https://1.2.3.4
  name: development
- cluster:
    insecure-skip-tls-verify: true
    server: https://5.6.7.8
  name: scratch
contexts: null
current-context: ""
kind: Config
preferences: {}
users: null
[root@nccztsjb-node-11 config-exercise]# 

(4)删除集群

kubectl config --kubeconfig=config-demo unset clusters.development

设置用户

(1)设置用户,使用客户端的证书和客户端密钥,并且将证书数据嵌入到配置文件中

kubectl config --kubeconfig=config-demo set-credentials developer --client-certificate=fake-cert-file --client-key=fake-key-seefile --embed-certs=true

注意:客户端证书和key必须要存在。

(2)设置用户,使用用户名和密码

kubectl config --kubeconfig=config-demo set-credentials experimenter --username=exp --password=some-password

(3)删除用户

kubectl config --kubeconfig=config-demo unset users.experimenter

experimenter这个就是使用set-credentials参数后面的名字。


增加上下文信息context

kubectl config --kubeconfig=config-demo set-context dev-frontend --cluster=development --namespace=frontend --user=developer

设置context将集群、命名空间、用户进行分组。即在dev-fronted这个context的以developer用户的信息访问developement集群的frontend命名空间。

kubectl config --kubeconfig=config-demo set-context dev-storage --cluster=development --namespace=storage --user=developer

dev-stroage这个context访问stroage命名空间。

查看通过以上的所有配置形成的kubeconfig文件

[root@nccztsjb-node-11 config-exercise]# cat config-demo 
apiVersion: v1
clusters:
- cluster:
    certificate-authority: fake-ca-file
    server: https://1.2.3.4
  name: development
- cluster:
    insecure-skip-tls-verify: true
    server: https://5.6.7.8
  name: scratch
contexts:
- context:
    cluster: development
    namespace: frontend
    user: developer
  name: dev-frontend
- context:
    cluster: development
    namespace: storage
    user: developer
  name: dev-storage
- context:
    cluster: scratch
    namespace: default
    user: experimenter
  name: exp-scratch
current-context: ""
kind: Config
preferences: {}
users:
- name: developer
  user:
    client-certificate: fake-cert-file
    client-key: fake-key-seefile
- name: experimenter
  user:
    password: some-password.
    username: exp

设置当前的context

kubectl config --kubeconfig=config-demo use-context dev-frontend

查看当前的context

kubectl config --kubeconfig=config-demo current-context

只查看和当前context有关的配置信息

[root@nccztsjb-node-11 config-exercise]# kubectl config --kubeconfig=config-demo view --minify
apiVersion: v1
clusters:
- cluster:
    certificate-authority: fake-ca-file
    server: https://1.2.3.4
  name: development
contexts:
- context:
    cluster: development
    namespace: frontend
    user: developer
  name: dev-frontend
current-context: dev-frontend
kind: Config
preferences: {}
users:
- name: developer
  user:
    client-certificate: fake-cert-file
    client-key: fake-key-seefile

那么kubeconfig中的其他的信息就不会显示


查看配置中所有的context

[root@nccztsjb-node-11 config-exercise]# kubectl config --kubeconfig=config-demo get-contexts
CURRENT   NAME           CLUSTER       AUTHINFO       NAMESPACE
*         dev-frontend   development   developer      frontend
          dev-storage    development   developer      storage
          exp-scratch    scratch       experimenter   default
<think>好的,我现在需要解释一下 Kuberneteskubeconfig 文件内容。首先,我得确认自己对 kubeconfig 的理解是否正确,然后组织一个清晰的中文解释。 kubeconfigKubernetes 用来配置访问集群的文件,通常位于 ~/.kube/config。它包含了集群、用户和上下文的信息。用户可能需要配置多个集群,比如开发、测试和生产环境,kubeconfig 可以管理这些不同的配置。 接下来,我需要回忆 kubeconfig 文件的具体结构。它主要包含三个部分:clusters、users 和 contexts。每个集群条目包括名称、服务器地址和证书信息;用户条目包括名称和认证信息,比如客户端证书或令牌;上下文则关联集群和用户,还可能指定默认的命名空间。 可能还需要提到如何切换上下文,比如使用 kubectl config use-context 命令。另外,环境变量 KUBECONFIG 可以指定多个配置文件,合并配置时需要注意优先级。 需要注意的是,用户可能对 YAML 结构不太熟悉,所以需要用简单明了的语言描述每个字段的作用。同时,可能存在的常见问题,比如证书路径错误或权限问题,也应该简要提及。 最后,确保整个解释结构清晰,分点说明,并给出一个示例文件的结构,帮助用户更好地理解。</think>**Kuberneteskubeconfig 文件详解** kubeconfigKubernetes 中用于管理集群访问权限的核心配置文件,本质是一个 **YAML 格式的文本文件**(默认路径:`~/.kube/config`)。它通过定义三要素(集群、用户、上下文)实现 **多集群环境下的无缝切换**。 --- ### **核心组成部分** #### 1. 集群配置(`clusters`) 定义可访问的 Kubernetes 集群信息: ```yaml clusters: - name: production-cluster # 集群别名(自定义标识) cluster: server: https://api.prod.com:6443 # 集群API Server地址 certificate-authority-data: LS0t... # 集群CA证书(Base64编码) # 或 certificate-authority: /path/to/ca.crt(证书文件路径) ``` #### 2. 用户身份(`users`) 配置访问集群的认证凭证: ```yaml users: - name: admin-user # 用户别名(自定义标识) user: client-certificate-data: LS0t... # 客户端证书(Base64) client-key-data: LS0t... # 私钥(Base64) # 或使用其他认证方式: # token: xxxx # Bearer Token # username/password: ... # 基本认证 ``` #### 3. 上下文绑定(`contexts`) 关联集群与用户,并支持附加配置: ```yaml contexts: - name: prod-admin@production # 上下文名称(建议格式:用户@集群) context: cluster: production-cluster # 关联的集群名称 user: admin-user # 关联的用户名称 namespace: default # (可选)默认命名空间 ``` --- ### **高级配置特性** 1. **多配置文件合并** 通过 `KUBECONFIG` 环境变量指定多个文件(Linux/macOS示例): ```bash export KUBECONFIG=~/.kube/config:~/.kube/config-demo ``` Kubernetes 会自动合并配置,同名条目按加载顺序覆盖。 2. **上下文快速切换** ```bash kubectl config use-context prod-admin@production # 切换至生产环境 kubectl config current-context # 查看当前上下文 ``` 3. **证书内嵌与路径引用** - **内嵌数据**:使用 `*-data` 字段直接存储 Base64 编码内容(适合自动化场景) - **文件路径**:通过 `certificate-authority` 等字段指定本地文件路径(便于手动管理) --- ### **典型应用场景** 1. **开发/生产环境隔离** 通过不同上下文切换测试集群与生产集群: ```yaml contexts: - name: dev@test-cluster context: {cluster: test-cluster, user: dev-user} - name: prod@production-cluster context: {cluster: production-cluster, user: ci-bot} ``` 2. **多租户权限管理** 结合 RBAC 为不同用户绑定差异化权限: ```yaml users: - name: app-developer # 普通开发者 user: {token: "xxxx"} - name: cluster-admin # 运维管理员 user: {client-certificate: /keys/admin.crt, ...} ``` --- ### **故障排查技巧** 1. **验证配置有效性** ```bash kubectl cluster-info # 检查当前上下文是否可达 kubectl get ns # 测试基础权限 ``` 2. **查看解析后的完整配置** ```bash kubectl config view --raw # 显示合并后的实际生效配置 ``` 3. **证书相关错误处理** - 检查时间同步:`date`(证书有效期依赖系统时间) - 验证证书链完整性:`openssl verify -CAfile ca.crt client.crt` --- **示例文件结构**: ```yaml apiVersion: v1 kind: Config current-context: dev@test-cluster # 当前激活的上下文 clusters: - {name: test-cluster, cluster: {server: https://1.2.3.4, certificate-authority-data: ...}} users: - {name: dev-user, user: {client-certificate-data: ..., client-key-data: ...}} contexts: - {name: dev@test-cluster, context: {cluster: test-cluster, user: dev-user}} ``` 通过合理配置 kubeconfig,可实现高效的多集群管理和安全的权限控制。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

墨鸦_Cormorant

大家喜欢的话可以点个关注投币哟

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值