client-go连接kubernetes集群

背景:

kubernetes的基本应用的算是能入门了。但是基于各种客户端操作kubernetes集群还是没有深入玩过,最近一段时间入门了一下goland,就拿client-go深入体验一下kubernetes集群的基本操作,当然了最后能更深入一下跟gin框架结合了就好了......算是练手入门
关于client-go
参照githubhttps://github.com/kubernetes/client-go。请注意版本与kubernetes的版本兼容性对应关系:https://github.com/kubernetes/client-go#versioning。我这里安装的最新的1.23.6版本(连接的集群其实是1.22的阿里云的ack集群。只进行简单的操作,没有什么太大问题)

实验环境

阿里云ack1.22.3
image.png
开发环境Goland2022.1
image.png

上手client-go连接kubernetes集群

创建项目k8s-demo1 go get安装依赖

image.png
创建好目录结构如下:
image.png
接下来应该是安装client-go的依赖了,参照client-go官方文档:https://github.com/kubernetes/client-go/blob/master/INSTALL.md。当然了我这里就按照最新版本了

go get  k8s.io/client-go@v0.23.6

注意:由于之前安装过,下载很是快了.....
image.png

api官方文档

https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.23/

关于client-go连接kubernetes集群的几种客户端

参照:csdn博客https://xinchen.blog.csdn.net/article/details/113753087

  1. client-go实战之二:RESTClient
  2. client-go实战之三:Clientset
  3. client-go实战之四:dynamicClient
  4. client-go实战之五:DiscoveryClient

我这里就使用Clientset了!

clientset创建kubernetes客户端并验证version

下载集群配置文件

登录阿里云ack集群管理页面下载config配置文件保存到开发机器C:\Users\zhangpeng.kube下:
image.png
image.png
注:当然了很多自建的集群填写的都是内网的方式,可以通过代理或者其他方式连接集群

第一个例子打印一下kubernetes集群version

package main

import (
    "flag"
    "fmt"
    "k8s.io/client-go/kubernetes"
    "k8s.io/client-go/tools/clientcmd"
    "k8s.io/client-go/util/homedir"
    "path/filepath"
)

func main() {
    var kubeconfig *string
    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.Error())
    }

    // create the clientset
    clientset, err := kubernetes.NewForConfig(config)
    if err != nil {
        panic(err.Error())
    }
    fmt.Println(clientset.ServerVersion())
}

go run main.go的时候报错了貌似少了依赖包。按照提示按照了一下

 go get k8s.io/client-go/kubernetes@v0.23.6
go get k8s.io/client-go/tools/clientcmd@v0.23.6

image.png
ok.打印了集群的版本v1.22.3.完成。扩展一下 我打印一下namespace列表?

第二个例子打印namespace列表

参照文档https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.23/#namespace-v1-core
namespace也是属于corev1的,看一下怎么打印一下命名空间列表呢?
main.go增加了如下配置:

    list, _ := clientset.CoreV1().Namespaces().List(context.Background(), metav1.ListOptions{})
    for _, item := range list.Items {
        fmt.Println(item.Name)

    }

说明:
列表就是定义list了,err忽略。corev1输入那么补全了namespaces。下一步出现了List将鼠标放在List上的提示继续补全:

func (NamespaceInterface) List(ctx context.Context, opts v1.ListOptions) (*v1.NamespaceList, error

常用的两个context:

  • context.Background():可以简单理解我们知道这个上下文要去干什么
  • context.TODO():可以简单理解我们不清楚要使用哪个上下文、或者还没有可用的上下文

就按照这里的去理解了https://www.jianshu.com/p/755426897746。最笨的方法可以一个一个试试.....,在后面其实补全的是v1.ListOptions{}。但是v1后面会和其他的类冲突。按照惯例设置为metav1.当然了也记得在import中设置

metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"

image.png
同理,下面打印一下develop命名空间一下的pod...

第三个例子打印develop namespace下的pod

    fmt.Println("pod list in develop")
    list1, _ := clientset.CoreV1().Pods("develop").List(context.Background(), metav1.ListOptions{})
    for _, item := range list1.Items {
        fmt.Println(item.Name)

    }

image.png
其他service deployment都差不多的了。这里就先演示一下简单的应用。

强调的:

  1. CoreV1 AppV1
  2. context的用法
  3. metav1
  4. 其他连接kubernetes的集群方式

29 声望
9 粉丝
0 条评论
推荐阅读
Ubuntu20.4 docker运行stable diffusion webui
环境前提系统环境ubuntu20.04 {代码...} nvida cuda显卡驱动默认已经安装成功 {代码...} 安装配置dockerupgrade系统更新系统依赖: {代码...} 卸载之前的Docker环境确认是否之前安装过docker并卸载: {代码...} ...

对你无可奈何阅读 108

Helm3-安装RabbitMQ
最近在使用k8s搭建微服务时,发现需要手动修改yaml文件里面的pod name、pod image、svc name、ingress tls等等,非常麻烦,但是有了helm之后情况就不一样了,helm是k8s的包管理器,类似ubuntu的apt-get,centos的...

Awbeci阅读 9.6k

Kubernetes Gateway API 深入解读和落地指南
Kubernetes Gateway API 是 Kubernetes 1.18 版本引入的一种新的 API 规范,是 Kubernetes 官方正在开发的新的 API,Ingress 是 Kubernetes 已有的 API。Gateway API 会成为 Ingress 的下一代替代方案。Gateway A...

Rainbond2阅读 456

Jvm调优与微服务资源分配
在没有接触微服务之前,我们的java程序一般都部署在WebLogic、Tomcat这类应用服务器上,这些应用服务器本身也是基于Jvm虚拟机的。一般我们统一对应用服务器做Jvm参数调优(分配多大内存,线程池限制等),而不用...

KerryWu阅读 6.1k

K8S-使用Helm安装RabbitMQ和Redis的总结
记得去年2021上半年的时候自学了k8s并且使用helm安装了rabbitmq和redis,可以在开发、测试和生产环境上用起来,但是下半年之后就没有用,再拾起来的时候发现好多知识点都忘了,这篇文章就是总结使用helm安装rabbm...

Awbeci1阅读 1.9k

Kubernetes v1.27 新特性一览
Kubernetes v1.27 是 2023 年的第一个大版本更新,包含了近 60 项主要的更新。 而 1.26 只有 37 项,所以这个版本可以说是一个变化非常显著的版本了。

张晋涛1阅读 1.1k

封面图
实战:用“廉价”的NFS作为K8S后端存储
大家都知道,NFS是一种基于网络的文件系统协议,允许在不同的机器之间共享文件系统资源。在K8S中,可以使用NFS作为后端存储,以提供持久化存储和共享存储卷。但是否适合在生产环境使用NFS作为后端存储,这取决于...

不背锅运维2阅读 770

29 声望
9 粉丝
宣传栏