博客
关于我
kubernetes中kubeconfig的用法
阅读量:434 次
发布时间:2019-03-06

本文共 1141 字,大约阅读时间需要 3 分钟。

在一个启用了TLS的 Kubernetes 集群中,集群访问不可或缺的就是身份认证,而使用kubeconfig(即证书)和token两种方式是最简单也是最通用的认证方式。

kubeconfig 配置简述

以kubectl为例来讲解kubeconfig的配置。kubectl本质上是一个用Go编写的可执行程序,只要给kubectl配置了合适的kubeconfig,就可以在集群中的任意节点上使用。默认情况下,kubectl会从$HOME/.kube目录下查找文件名为config的文件,也可以通过设置环境变量KUBECONFIG或者通过命令去指定其他kubeconfig文件。

集群参数配置

通过以下命令可以设置所需访问的集群信息:

kubectl config set-cluster kubernetes \  --certificate-authority=/etc/kubernetes/ssl/ca.pem \  --embed-certs=true \  --server=https://172.20.0.113:6443

用户参数配置

设置客户端认证参数:

kubectl config set-credentials admin \  --client-certificate=/etc/kubernetes/ssl/admin.pem \  --embed-certs=true \  --client-key=/etc/kubernetes/ssl/admin-key.pem

上下文参数配置

将集群参数和用户参数关联起来:

kubectl config set-context kubernetes \  --cluster=kubernetes \  --user=admin

最后,设置默认上下文:

kubectl config use-context kubernetes

注意事项

生成的kubeconfig会被保存到~/.kube/config文件中。该文件描述了集群、用户和上下文的信息。集群参数设置了要访问的集群信息,用户参数设置了客户端的认证信息,上下文参数将集群参数和用户参数关联起来。

在实际操作中,用户需要确保其证书已经被集群CA签署。例如,在上述示例中,用户证书的OU字段为system:masters,这通常意味着该用户已经被授权访问集群API(通过RBAC授权)。具体到kube-apiserver,预定义的cluster-admin角色将system:masters组和cluster-admin角色绑定,从而授予了访问kube-apiserver相关API的权限。

参考资料

转载地址:http://sqakz.baihongyu.com/

你可能感兴趣的文章
OpenCV与AI深度学习 | 实战 | 基于YoloV5和Mask RCNN实现汽车表面划痕检测(步骤 + 代码)
查看>>
OpenCV与AI深度学习 | 干货 | 深度学习模型训练和部署的基本步骤
查看>>
OpenCV与AI深度学习 | 手把手教你用Python和OpenCV搭建一个半自动标注工具(详细步骤 + 源码)
查看>>
OpenCV与AI深度学习 | 深度学习检测小目标常用方法
查看>>
Opencv中KNN背景分割器
查看>>
OpenCV中基于已知相机方向的透视变形
查看>>
opencv中读写视频
查看>>
opencv之namedWindow,imshow出现两个窗口
查看>>
opencv之模糊处理
查看>>
opencv保存图片路径包含中文乱码解决方案
查看>>
opencv图像分割2-GMM
查看>>
opencv图像分割3-分水岭方法
查看>>
OpenCV学习(13) 细化算法(1)(转)
查看>>
OpenCV学堂 | OpenCV案例 | 基于轮廓分析对象提取
查看>>
OpenCV探索
查看>>
opencv笔记(1):图像缩放
查看>>
opencv面向对象设计初探
查看>>
OpenCV(1)读写图像
查看>>
OpenCV:概念、历史、应用场景示例、核心模块、安装配置
查看>>
OpenDaylight融合OpenStack架构分析
查看>>