k8s在go语言中的使用及client 初始化简介

 更新时间:2022年04月22日 12:45:35   作者:zziawan  
这篇文章主要为大家介绍了k8s在go语言中的使用及client 初始化简介,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

作为k8s官方维护的客户端,k8s go-client对于go语言中使用k8s可以说是唯一选项。但是官方的使用示例我个人觉得并不是很清晰,尤其是对于对于k8s并不熟悉的用户。这里我总结一下使用过程中碰到的坑,也希望能给有需要的人一些参考。

首先从官方示例说起:这里先解释一下k8s连接问题。集群的节点上会有一个.kube目录(这个目录一般在root用户home目录下)目录中会存在一个config文件,文件中记录了连接k8s集群所需的所有信息,如apiserver地址,用户认证token等。一般来说客户端连接集群均需要此配置文件。一下就是官方示例代码。

var kubeconfig *string
    //配置了config目录就读取该目录下的config信息
    if home := homedir.HomeDir(); home != "" {
        kubeconfig = flag.String("kubeconfig", filepath.Join(home, ".kube", "config"), "(optional) absolute path to the kubeconfig file")
    } else {
        //否则就需要指定配置文件路径
        kubeconfig = flag.String("kubeconfig", "", "absolute path to the kubeconfig file")
    }
    flag.Parse()
    config, err := clientcmd.BuildConfigFromFlags("", *kubeconfig)
    if err != nil {
        panic(err)
    }
    clientset, err := kubernetes.NewForConfig(config)
    if err != nil {
        panic(err)
    }

可以看到初始化go-client必须要指定config文件。但是实际使用中往往没有这里理想化,比如我们的代码运行在集群外,再比如我们的代码连接的client需要在不同集群上来回切换,更甚者我们需要连接的集群会随时改变,集群数量改变,集群的连接信息改变。总之很多情况下无法直接从集群获取到config文件,也无法使用固定的config文件。

总体上来说,使用场景包括集群内和集群外访问,同时也可以分为固定访问和动态访问。对于集群内且集群的配置是固定的,使用起来还是相当简单。

1、集群内且集群配置固定,以进程方式运行,即代码编译后直接以进程的方式运行在集群的某个节点上且只会访问本地或外部固定集群。这种情况下,本地集群config文件路径是固定的,外部集群可以提前把config文件放到本地,使用示例代码的配置方式即可

2、集群内且集群配置固定,以pod方式运行。对于本地集群,虽然pod就跑在集群中,但是容器的因为隔离性,无法获取集群的配置信息。此时可以通过默认配置跟k8s RBAC进行本地集群访问,即使用pod中的默认apiserver地址和端口环境变量(可以直接使用go-client的默认config rest.InclusterConfig)连接集群,同时给pod配置集群的admin角色即可。也可以将.kube目录挂载到pod上,通过读取该目录中的配置文件初始化客户端。访问外部集群跟1中的方式无太大差别。

3、需要访问的集群不固定(集群数量随时增减,集群认证信息会过期),这种情况下无论是否运行在容器中都不太好使用官方的示例代码来连接集群。此种情况下需要一个能够获取集群认证信息(token,user password等)的地方。有了这些信息代码中就可以手动新建config,通过这个config来初始化集群,同时在认证信息失效后及时重新初始化

手动指定apiserver地址,这里地址可以是url也可以主机加端口   

kubeconfig,er := clientcmd.BuildConfigFromFlags(apiUrl,"")

配置认证信息,token或者用户名加密码或者其他认证方式

kubeconfig.BearerToken = token

初始化client

clientset, err := kubernetes.NewFo,rConfig(kubeconfig)

当发生变动或者认证信息失效时,客户端或报相应的权限错误,即可重新获取认证信息,重新初始化。这样可以保证不重启程序,不手动修改配置的情况下适应集群变动

以上就是k8s在go语言中的使用及client 初始化简介的详细内容,更多关于k8s go client初始化的资料请关注脚本之家其它相关文章!

相关文章

  • GoFrame ORM原生方法操作示例

    GoFrame ORM原生方法操作示例

    这篇文章主要为大家介绍了GoFrame ORM原生方法操作示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • Go语言的数据结构转JSON

    Go语言的数据结构转JSON

    本文主要介绍了Go语言的数据结构转JSON,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • 自己动手用Golang实现约瑟夫环算法的示例

    自己动手用Golang实现约瑟夫环算法的示例

    这篇文章主要介绍了自己动手用Golang实现约瑟夫环算法的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-12-12
  • 手把手教你如何在Goland中创建和运行项目

    手把手教你如何在Goland中创建和运行项目

    欢迎来到本指南!我们将手把手地教您在Goland中如何创建、配置并运行项目,通过简单的步骤,您将迅速上手这款强大的集成开发环境(IDE),轻松实现您的编程梦想,让我们一起开启这段精彩的旅程吧!
    2024-02-02
  • GoLang之使用Context控制请求超时的实现

    GoLang之使用Context控制请求超时的实现

    这篇文章主要介绍了GoLang之使用Context控制请求超时的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • 解决Golang中goroutine执行速度的问题

    解决Golang中goroutine执行速度的问题

    这篇文章主要介绍了解决Golang中goroutine执行速度的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-05-05
  • 解析Go 中的 rune 类型

    解析Go 中的 rune 类型

    rune类型是 Go 语言的一种特殊数字类型,Go 语言通过rune处理中文,支持国际化多语言,本文给大家介绍Go 中的 rune 类型,感兴趣的朋友一起看看吧
    2022-03-03
  • Go语言map元素的删除和清空

    Go语言map元素的删除和清空

    本文主要介绍了Go语言map元素的删除和清空,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • Golang分布式锁详细介绍

    Golang分布式锁详细介绍

    分布式锁是控制分布式系统之间同步访问共享资源的一种方式。如果不同的系统或是同一个系统的不同主机之间共享了一个或一组资源,那么访问这些资源时,需要通过一些互斥手段来防止彼此之间的干扰以保证一致性,在这种情况下,就需要使用分布式锁了
    2022-10-10
  • 一文带你掌握Golang中panic与recover的使用方法

    一文带你掌握Golang中panic与recover的使用方法

    这篇文章主要介绍了Golang中panic与recover的作用和使用方法,文中的示例代码讲解详细,具有一定的学习价值,需要的小伙伴可以参考一下
    2023-04-04

最新评论