返回顶部
首页 > 资讯 > 精选 >k8s中kubeconfig怎么配置使用
  • 514
分享到

k8s中kubeconfig怎么配置使用

2023-06-26 07:06:06 514人浏览 八月长安
摘要

这篇文章主要讲解了“k8s中kubeconfig怎么配置使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“k8s中kubeconfig怎么配置使用”吧!1、概述kubeconfig文件保存了

这篇文章主要讲解了“k8s中kubeconfig怎么配置使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“k8s中kubeconfig怎么配置使用”吧!

    1、概述

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

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

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

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

    • clusters (集群)

    • users(用户)

    • context(上下文)

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

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

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

    • 用户使用token进行认证

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

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

    3、Context的定义

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

    每个context都有3个参数:

    • cluster (集群)

    • namespace(命名空间)

    • user(用户)

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

    4、查看kubeconfig的配置

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

    [root@nccztsjb-node-11 ~]# kubectl config viewapiVersion: v1clusters:- cluster:    certificate-authority-data: DATA+OMITTED    server: https://k8s.apiserver.io:6443  name: cluster.localcontexts:- context:    cluster: cluster.local    user: kubernetes-admin-cluster.local  name: kubernetes-admin-cluster.local@cluster.localcurrent-context: kubernetes-admin-cluster.local@cluster.localkind: Configpreferences: {}users:- name: kubernetes-admin-cluster.local  user:    client-certificate-data: REDACTED    client-key-data: REDACTED[root@nccztsjb-node-11 ~]#

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

    5、kubeconfig设置

    5.1、设置集群

    (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: v1clusters:- cluster:    certificate-authority-data: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1jsUM2VENDQWRHZ0F3SUJBZ0lCQURBTkJna3Foa2lHOXcwQkFRc0ZBREFWTVJNd0VRWURWUVFERXdwcmRXSmwKY201bGRHVnpNQ0FYRFRJeE1USXdNakE0TURjMU5sb1lEekl4TVRFeE1URXhNRGd3TnpVMldqQVZNUk13RVFZRApWUVFERXdwcmRXSmxjbTVsZEdWek1JSUJJakFOQmdrcWhraUc5dzBCQVFFRkFBT0NBUThBTUlJQkNnS0NBUUVBCnFaWkVNZDhORHpoek5hTE1ab2tCenlabVUzQWh7R1Z4OW15MzJxaTB3UzkzS3Jib0xMUWhSSUhCYnYzdzZCbCsKZlBYaUdSeCt4OVpKY2lta1BqdmJtQ0ZpKzEvQmsxZkFONlNBSi9ISjJoenQxcExZbW41NXVVclpqdmFCTXNUdAp5U3B4QUlOUWNNU1NJYUFyeHF1VDJ0QjYzWkMvTHloQVFWWG4xL2lYS3hLTmpidjVlS21BdlRRTlQrNlMxaFIxCkJNQXNjSFc0R1lhNXVBTFZBTmZrVlpGaG5GMmt2cVMyRzRDMXV4emZtOFpyUnREOExRUjFmTnk1VnpnVkJLQjMKT2RKQkExNnl4YXk5N2JjaEtqenpQtmxKMFBlVDBOdFZZWVRlZ3F1ZG5iRURRSEdObC91Ym5UcGtWWHpFUGRKNAo3a3FQREdWUzRXYi9DZXpVcm9IQ1hRSURBUUFCbzBJd1FEQU9CZ05WSFE4QkFmOEVCQU1DQXFRd0R3WURWUjBUCkFRSC9CQVV3QXdFQi96QWRCZ05WSFE0RUZnUVVMQldoK3hIdlVSdFdKdUVuUUlYTHRDUzh3MEl3RFFZSktvWkkKaHZjTkFRRUxCUUFEZ2dFQkFHeHNvSXJOZkJYRkp1RjZwYmtvSkh4eVdCSkp0Qzlud1VabWNCMmYzT0xTZTN4LwpQQU5oYm9LcHZ6ME5ocm5IQ2VnUk1rWGlmSmhKZW9VU25sYUhJaWpjVlFDZ09sTDVnT0EyeFZkRk01MlZCTk5jCnN1Qmp2MHJoQnZXMWxaYWVEUGJuaGp3DGY5elp2WG4vMUkvZ1RKSVRiNmFVdk55b1U3WHY2c3RmN1NjaExwU3kKZmVwRjNKRFc5TXRvem9yMHhoV0U3M0FrZHE1bnE4OFlSdEcxK3UwRTJXbDJ5U20yR0dzRUkvcU1HOXlvd0NsRGozSnhOQm45MEk3V0xKd0pETGZZMXYwWXdRNDR3QUJteGN4R01qVzNmOHAvL3pxSHNaaXJGdTR3QUlUK003Mmw3CkhDbXAwbm84VXpKMUdMUFcxNzF5TWNsdlJNM3h3SENtZHd0VktBMD0KLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQo=    server: https://1.2.3.4  name: developmentcontexts: nullcurrent-context: ""kind: Configpreferences: {}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.4Cluster "development" set.[root@nccztsjb-node-11 config-exercise]# cat config-demo apiVersion: v1clusters:- cluster:    server: https://1.2.3.4  name: developmentcontexts: nullcurrent-context: ""kind: Configpreferences: {}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: v1clusters:- cluster:    certificate-authority-data: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUM2VENDQWRHZ0F3SUJBZ0lCQURBTkJna3Foa2lHOXcwQkFRc0ZBREFWTVJNd0VRWURWUVFERXdwcmRXSmwKY201bGRHVnpNQ0FYRFRJeE1USXdNakE0TURjMU5sb1lEekl4TVRFeE1URXhNRGd3TnpVMldqQVZNUk13RVFZRApWUVFERXdwcmRXSmxjbTVsZEdWek1JSUJJakFOQmdrcWhraUc5dzBCQVFFRkFBT0NBUThBTUlJQkNnS0NBUUVBCnFaWkVNZDhORHpoek5hTE1ab2tCenlabVUzQWh7R1Z4OW15MzJxaTB3UzkzS3Jib0xMUWhSSUhCYnYzdzZCbCsKZlBYaUdSeCt4OVpKY2lta1BqdmJtQ0ZpKzEvQmsxZkFONlNBSi9ISjJoenQxcExZbW41NXVVclpqdmFCTXNUdAp5U3B4QUlOUWNNU1NJYUFyeHF1VDJ0QjYzWkMvTHloQVFWWG4xL2lYS3hLTmpidjVlS21BdlRRTlQrNlMxaFIxCkJNQXNjSFc0R1lhNXVBTFZBTmZrVlpGaG5GMmt2cVMyRzRDMXV4emZtOFpyUnREOExRUjFmTnk1VnpnVkJLQjMKT2RKQkExNnl4YXk5N2JjaEtqenpqTmxKMFBlVDBOdFZZWVRlZ3F1ZG5iRURRSEdObC91Ym5UcGtWWHpFUGRKNAo3a3FQREdWUzRXYi9DZXpVcm9IQ1hRSURBUUFCbzBJd1FEQU9CZ05WSFE4QkFmOEVCQU1DQXFRd0R3WURWUjBUCkFRSC9CQVV3QXdFQi96QWRCZ05WSFE0RUZnUVVmQldoK3hIdlVSdFdKdUVuUUlYTHRDUzh3MEl3RFFZSktvWkkKaHZjTkFRRUxCUUFEZ2dFQkFHeHNvSXJOZkJYRkp1RjZwYmtvSkh4eVdCSkp0Qzlud1VabWNCMmYzT0xTZTN4LwpQQU5oYm9LcHZ6ME5ocm5IQ2VnUk1rWGlmSmhKZW9VU25sYUhJaWpjVlFDZ09sTDVnT0EyeFZkRk01MlZCTk5jCnN1Qmp2MHJoQnZXMWxaYWVEUGJuaGp3dGY5elp2WG4vMUkvZ1RKSVRiNmFVdk55b1U3WHY2c3RmN1NjaExwU3kKZmVwRjNKRFc5TXRvem9yMHhoV0U3M0FrZHE1bnE4OFlSdEcxK3UwRTJXbDJ5U20yR0dzRUkvcU1HOXlvd0NsRgozSnhOQm45MEk3V0xKd0pETGZZMXYwWXdRNDR3QUJteGN4R01qVzNmOHAvL3pxSHNaaXJGdTR3QUlUK003Mmw3CkhDbXAwbm84VXpKMUdMUFcxNzF5TWNsdlJNM3h3SENtZHd0VktBMD0KLS0tLS1FTkQgQ0VSVElGSUNBVEUtLS0tLQo=    server: https://1.2.3.4  name: development- cluster:    insecure-skip-tls-verify: true    server: https://5.6.7.8  name: scratchcontexts: nullcurrent-context: ""kind: Configpreferences: {}users: null[root@nccztsjb-node-11 config-exercise]#

    (4)删除集群

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

    5.2、设置用户

    (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参数后面的名字。

    5.3、增加上下文信息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: v1clusters:- 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: scratchcontexts:- 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-scratchcurrent-context: ""kind: Configpreferences: {}users:- name: developer  user:    client-certificate: fake-cert-file    client-key: fake-key-seefile- name: experimenter  user:    password: some-password.    username: exp

    5.4、设置当前的context

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

    查看当前的context

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

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

    kubectl config --kubeconfig=config-demo view --minify
    [root@nccztsjb-node-11 config-exercise]# kubectl config --kubeconfig=config-demo view --minifyapiVersion: v1clusters:- cluster:    certificate-authority: fake-ca-file    server: https://1.2.3.4  name: developmentcontexts:- context:    cluster: development    namespace: frontend    user: developer  name: dev-frontendcurrent-context: dev-frontendkind: Configpreferences: {}users:- name: developer  user:    client-certificate: fake-cert-file    client-key: fake-key-seefile

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

    5.6、查看配置中所有的context

    [root@nccztsjb-node-11 config-exercise]# kubectl config --kubeconfig=config-demo get-contextsCURRENT   NAME           CLUSTER       AUTHINFO       NAMESPACE*         dev-frontend   development   developer      frontend          dev-storage    development   developer      storage          exp-scratch    scratch       experimenter   default

    感谢各位的阅读,以上就是“k8s中kubeconfig怎么配置使用”的内容了,经过本文的学习后,相信大家对k8s中kubeconfig怎么配置使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

    --结束END--

    本文标题: k8s中kubeconfig怎么配置使用

    本文链接: https://lsjlt.com/news/307365.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    猜你喜欢
    • k8s中kubeconfig怎么配置使用
      这篇文章主要讲解了“k8s中kubeconfig怎么配置使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“k8s中kubeconfig怎么配置使用”吧!1、概述kubeconfig文件保存了...
      99+
      2023-06-26
    • k8s中kubeconfig的配置以及使用详解
      目录1、概述2、kubeconfig支持多集群、多用户、多认证3、Context的定义4、查看kubeconfig的配置5、kubeconfig设置5.1、设置集群5.2、设置用户5...
      99+
      2024-04-02
    • K8S实用工具之怎么合并多个kubeconfig
      这篇文章主要介绍“K8S实用工具之怎么合并多个kubeconfig”,在日常操作中,相信很多人在K8S实用工具之怎么合并多个kubeconfig问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”K8S实用工具之怎...
      99+
      2023-07-05
    • k8s中的secret怎么使用
      这篇文章主要讲解了“k8s中的secret怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“k8s中的secret怎么使用”吧!secret可以加密用户名和密码文件,将其打包成一个sec...
      99+
      2023-07-06
    • K8S ConfigMap怎么实现应用和配置分离
      这篇文章主要介绍了K8S ConfigMap怎么实现应用和配置分离的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇K8S ConfigMap怎么实现应用和配置分离文章都会有所收获,下面我们一起来看看吧。Confi...
      99+
      2023-07-05
    • docker中k8s怎么用
      小编给大家分享一下docker中k8s怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!   之前安装了一个master和两个nodes的k...
      99+
      2023-06-04
    • k8s如何部署高可用配置中心apollo
      这篇文章主要讲解了“k8s如何部署高可用配置中心apollo”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“k8s如何部署高可用配置中心apollo”吧!部署...
      99+
      2024-04-02
    • vue中router怎么配置使用
      这篇文章主要介绍了vue中router怎么配置使用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 路由,其实就是指向的意思,当我点击页面上的...
      99+
      2024-04-02
    • idea中怎么配置使用gitlab
      Git是一个流行的版本控制系统,它允许用户在开发过程中进行版本控制,并协作开发代码。GitLab是一个基于Git的网站,它为用户提供了一个使用Git进行版本控制的平台。Idea是一个受欢迎的Java开发环境,它可以使用GitLab实现代码版...
      99+
      2023-10-22
    • Vue中怎么配置使用process.env
      这篇文章主要讲解了“Vue中怎么配置使用process.env”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue中怎么配置使用process.env”吧!vue process.envpr...
      99+
      2023-07-05
    • vue中怎么配置和使用mockjs
      这篇文章主要讲解了“vue中怎么配置和使用mockjs”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue中怎么配置和使用mockjs”吧!mockjs配置和使用方式需求在前后端分离的开发中...
      99+
      2023-06-29
    • Android中的OpenGL怎么配置使用
      这篇文章主要介绍“Android中的OpenGL怎么配置使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Android中的OpenGL怎么配置使用”文章能帮助大家解决问题。介绍Android 可通...
      99+
      2023-07-05
    • Linux中mplayer怎么配置和使用
      在Linux中,你可以通过以下步骤配置和使用mplayer: 安装mplayer:打开终端,运行以下命令安装mplayer: s...
      99+
      2023-10-23
      Linux mplayer
    • linux中Teminator怎么配置和使用
      在Linux中使用Terminator,你需要执行以下步骤来配置和使用它: 安装Terminator:打开终端并输入以下命令来安...
      99+
      2023-10-24
      linux Teminator
    • Eclipse中怎么配置和使用Docker
      在Eclipse中配置和使用Docker可以通过以下步骤来实现: 安装Docker插件:首先,在Eclipse的Marketpl...
      99+
      2024-04-03
      Eclipse Docker
    • k8s节点配置的步骤是什么
      在配置 k8s 节点之前,需要确保已经安装了 Docker 和 kubeadm。以下是配置 k8s 节点的步骤: 初始化 kube...
      99+
      2024-03-04
      k8s
    • Django怎么配置使用
      本篇内容主要讲解“Django怎么配置使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Django怎么配置使用”吧! 1. 准备工作   &nb...
      99+
      2024-04-02
    • 怎么配置使用redis
      本篇内容主要讲解“怎么配置使用redis”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么配置使用redis”吧!Spring-data-redis为spring-data模块中对redis的支...
      99+
      2023-06-04
    • k8s入门之deployment怎么使用
      这篇“k8s入门之deployment怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“k8s入门之deployment...
      99+
      2023-07-05
    • java中properties配置文件怎么使用
      在Java中,可以使用`java.util.Properties`类来读取和使用配置文件。首先,创建一个`Properties`对象...
      99+
      2023-09-17
      java properties
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作