client-go gin的简单整合一(list列表相关操作)

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
简介: 完成了client-go连接kubernetes集群-delete相关操作,稍微看过一些B站go圈里最会写js的奇淼 的go 与gin的视频,还有沈叔的一些课程:https://www.jtthink.com/。一般都是习惯先动手的,自己动手操作,有问题就看沈叔的视频与解决思路!

背景:

完成了client-go连接kubernetes集群-delete相关操作,稍微看过一些B站go圈里最会写js的奇淼 的go 与gin的视频,还有沈叔的一些课程:https://www.jtthink.com/。一般都是习惯先动手的,自己动手操作,有问题就看沈叔的视频与解决思路!

1. client-go gin的简单整合一

注:以下操作环境可能有些许区别(在家写东西用的windows,公司的办公环境个人安装了一台rocky linux)。一下所有路径为相对路径在k8s-demo1项目目录下!

1. go get 安装gin依赖

PS C:\Users\zhangpeng\GolandProjects\k8s-demo1> go get github.com/gin-gonic/gin

go get: added github.com/gin-contrib/sse v0.1.0

go get: added github.com/gin-gonic/gin v1.7.7

go get: added github.com/go-playground/locales v0.13.0

go get: added github.com/go-playground/universal-translator v0.17.0

go get: added github.com/go-playground/validator/v10 v10.4.1

go get: added github.com/leodido/go-urn v1.2.0

go get: added github.com/mattn/go-isatty v0.0.12

go get: added github.com/ugorji/go/codec v1.1.7


注:linux环境操作省略......如报错缺少其他依赖go get自行按照提示获取安装!

2. 将连接客户端单独封装成一个方法文件

将前面测试环境写的单独的文件拆分。把客户端单独封装成一个单独文件:

src/lib/K8sClient.go

package lib


import (

"flag"

"k8s.io/client-go/kubernetes"

"k8s.io/client-go/tools/clientcmd"

"k8s.io/client-go/util/homedir"

"path/filepath"

)


var K8sClient *kubernetes.Clientset


func init() {

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

c, err := kubernetes.NewForConfig(config)

if err != nil {

panic(err.Error())

}

K8sClient = c

}

3. 创建service目录创建namespace deployment service对应service文件

以namespace deployment service为例:

src/service/Namespace.go

package service


import (

"context"

"github.com/gin-gonic/gin"

. "k8s-demo1/src/lib"

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

)


func ListNamespace(g *gin.Context) {

ns, err := K8sClient.CoreV1().Namespaces().List(context.Background(), metav1.ListOptions{})

if err != nil {

g.Error(err)

return

}

g.JSON(200, ns)

}

src/service/Deployment.go

package service


import (

"context"

"github.com/gin-gonic/gin"

. "k8s-demo1/src/lib"

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

)


func ListDeployment(g *gin.Context) {

ns := g.Query("ns")


dps, err := K8sClient.AppsV1().Deployments(ns).List(context.Background(), metav1.ListOptions{})

if err != nil {

g.Error(err)

}

g.JSON(200, dps)

return

}

src/service/Service.go

package service


import (

"context"

"github.com/gin-gonic/gin"

. "k8s-demo1/src/lib"

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

)


func ListService(g *gin.Context) {

ns := g.Query("ns")

svc, err := K8sClient.CoreV1().Services(ns).List(context.Background(), metav1.ListOptions{})

if err != nil {

g.Error(err)

return

}

g.JSON(200, svc)

}


注:正常的应该是lib.K8sClient引用,import设置为了 . "k8s-demo1/src/lib"!

4.编辑main.go 设置路由

main.go

package main


import (

"github.com/gin-gonic/gin"

"k8s-demo1/src/service"

)


func main() {

r := gin.Default()

r.GET("/", func(context *gin.Context) {

context.JSON(200, "hello")

})

r.GET("/namespaces", service.ListNamespace)

r.GET("/deployments", service.ListDeployment)

r.GET("/service", service.ListService)

r.Run()

}


5. 运行main.go,浏览器访问是否正常返回

可以命令行控制台go run main.go 也可以goland直接run main.go

注:此集群非前面的ack集群,为本地内网一个测试集群!故namespace等相关信息输出并不与前面部分对应

1. namespace:

http://127.0.0.1:8080/namespaces

2. deployment

http://127.0.0.1:8080/deployments

http://127.0.0.1:8080/deployments?ns=default 指定命名空间

3. service

http://127.0.0.1:8080/service

http://127.0.0.1:8080/service?ns=default 指定命名空间

基本实现了个人的目的。但是输出的内容太多了,很多东西不需要,想要进一步优化输出自己先要的信息!

2. 更进一步的-定制化输出需要的内容

1.关于namespace

namespace我只想输出空间name! 创建一个struct,并make创建一个切片:

src/service/Namespace.go

package service


import (

"context"

"github.com/gin-gonic/gin"

. "k8s-demo1/src/lib"

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

)


type Namespace struct {

Name string

}


func ListNamespace(g *gin.Context) {

ns, err := K8sClient.CoreV1().Namespaces().List(context.Background(), metav1.ListOptions{})

if err != nil {

g.Error(err)

return

}

ret := make([]*Namespace, 0)

for _, item := range ns.Items {

ret = append(ret, &Namespace{

  Name: item.Name,

})


}

g.JSON(200, ret)

return

}


浏览器访问http://127.0.0.1:8080/namespaces,如下:

2. 关于deployment

参照namespace设置src/service/Deployment.go

package service


import (

"context"

"github.com/gin-gonic/gin"

. "k8s-demo1/src/lib"

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

)


type Deployment struct {

Name string

}


func ListDeployment(g *gin.Context) {

ns := g.Query("ns")


dps, err := K8sClient.AppsV1().Deployments(ns).List(context.Background(), metav1.ListOptions{})

if err != nil {

g.Error(err)

}

ret := make([]*Deployment, 0)

for _, item := range dps.Items {

ret = append(ret, &Deployment{

  Name: item.Name,

})


}

g.JSON(200, ret)

return

}


运行main.go 访问http://127.0.0.1:8080/deploymentshttp://127.0.0.1:8080/deployments?ns=default

3. 关于service

src/service/Service.go如下

package service


import (

"context"

"github.com/gin-gonic/gin"

. "k8s-demo1/src/lib"

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

)


type Service struct {

Name string

}


func ListService(g *gin.Context) {

ns := g.Query("ns")

svc, err := K8sClient.CoreV1().Services(ns).List(context.Background(), metav1.ListOptions{})

if err != nil {

g.Error(err)

return

}

ret := make([]*Service, 0)

for _, item := range svc.Items {

ret = append(ret, &Service{

  Name: item.Name,

})


}

g.JSON(200, ret)

return

}

运行main.go 访问http://127.0.0.1:8080/servicehttp://127.0.0.1:8080/service?ns=default

反思:

1.切片的使用,指针的使用......

2.定制化输出更多的相关配置?比如deployments中镜像,副本数。namespace中label?创建时间?

3.gin.Context该让我怎么去理解......

运行main.go 访问[http://127.0.0.1:8080/service](http://127.0.0.1:8080/service) [http://127.0.0.1:8080/service?ns=default](http://127.0.0.1:8080/service?ns=default)

![image.png](https://cdn.nlark.com/yuque/0/2022/png/2505271/1651740170966-44f978db-8818-4a96-85d4-4df22ea81f6d.png#clientId=ub84964fb-43e5-4&crop=0&crop=0&crop=1&crop=1&from=paste&height=468&id=u9431c166&margin=%5Bobject%20Object%5D&name=image.png&originHeight=468&originWidth=684&originalType=binary&ratio=1&rotation=0&showTitle=false&size=32924&status=done&style=none&taskId=u1c969fc8-1947-4f4f-b8cd-330c1431500&title=&width=684)

![image.png](https://cdn.nlark.com/yuque/0/2022/png/2505271/1651740213862-0dd8925d-c651-4ff7-83bf-550bc0fd0247.png#clientId=ub84964fb-43e5-4&crop=0&crop=0&crop=1&crop=1&from=paste&height=421&id=u692871a2&margin=%5Bobject%20Object%5D&name=image.png&originHeight=421&originWidth=408&originalType=binary&ratio=1&rotation=0&showTitle=false&size=23056&status=done&style=none&taskId=u5a4e3eee-4080-4cf3-b8a4-27720568889&title=&width=408)

# 反思:

1.切片的使用,指针的使用......

2.定制化输出更多的相关配置?比如deployments中镜像,副本数。namespace中label?创建时间?

3.gin.Context该让我怎么去理解......

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
10天前
|
JavaScript
DOM 节点列表长度(Node List Length)
DOM 节点列表长度(Node List Length)
|
1天前
|
JavaScript
DOM 节点列表长度(Node List Length)
DOM 节点列表长度(Node List Length)
|
12天前
|
JavaScript
DOM 节点列表长度(Node List Length)
DOM 节点列表长度(Node List Length)
|
3天前
|
JavaScript
DOM 节点列表长度(Node List Length)
DOM 节点列表长度(Node List Length)
|
4天前
|
存储 分布式计算 NoSQL
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
15 3
|
16天前
|
JavaScript
DOM 节点列表长度(Node List Length)
DOM 节点列表长度(Node List Length)
|
14天前
|
JavaScript
DOM 节点列表长度(Node List Length)
DOM 节点列表长度(Node List Length)
|
17天前
|
消息中间件 存储 NoSQL
4)深度解密 Redis 的列表(List)
4)深度解密 Redis 的列表(List)
15 1
|
8天前
|
JavaScript
DOM 节点列表长度(Node List Length)
DOM 节点列表长度(Node List Length)
|
9天前
|
索引 Python
Python列表操作-推导式(List Comprehension)
Python列表操作-推导式(List Comprehension)
13 0