开发 k8s 管理平台 - k8sailor 03. 使用 client-go sdk 链接集群

原文地址: https://tangx.in/posts/books/k8sailor/chapter01/03-connect-cluster/

tag: https://github.com/tangx/k8sailor/tree/feat/02-connect-cluster

使用 sdk 链接 k3s cluster 并获取 deployment 信息

1
2
3
4
cd cmd/k8sailor && go run .

 * my-nginx-1 (1 replicas)
 * my-nginx-2 (2 replicas)

下载 client-go sdk

之前在安装 k3s 集群的时候,版本是 v0.21.4。 因此。 这里选择 client-go sdk 的版本也是 v0.21.4

如果还有其他环境, 可以使用 go mod edit 命令锁定 client-go 的版本

1
2
3
go get k8s.io/[email protected]

go mod edit -replace=k8s.io/client-go=k8s.io/[email protected]

连接集群并获取 deployment

https://github.com/kubernetes/client-go/blob/master/examples/create-update-delete-deployment/main.go

连接到 cluster 的鉴权方式有多种, 后面可以根据 cobra 传递的参数值, 选择不同的鉴权方式。 这里直接参考官方 demo 使用配置文件方式鉴权。

修改一下 kubeconfig 配置来源地址。

pkg/k8s/cluster.go

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25

// 从 cobra 配置中获取地址
kubeconfig := &global.Flags.Config

// 其他一样
config, err := clientcmd.BuildConfigFromFlags("", *kubeconfig)
if err != nil {
    panic(err)
}
clientset, err := kubernetes.NewForConfig(config)
if err != nil {
    panic(err)
}


/* clientset 测试开始, 打印 default namespace 下的所有 deployment */
depClient := clientset.AppsV1().Deployments(apiv1.NamespaceDefault)
list, err := depClient.List(context.TODO(), metav1.ListOptions{})
if err != nil {
	panic(err)
}
for _, d := range list.Items {
	fmt.Printf(" * %s (%d replicas)\n", d.Name, *d.Spec.Replicas)
}
/* clienset 测试结束 */

运行

cmd/root.go 中调用 k8s cluster 的连接函数

1
2
3
4
5
6
7
var rootCmd = &cobra.Command{
	// .. 省略
	Run: func(cmd *cobra.Command, args []string) {
		// 连接 k3s
		k8s.Connent()
	},
}

运行结果如开篇所示。