前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >k8sailor - 03 ​连接 k3s 集群获取 deployment 信息

k8sailor - 03 ​连接 k3s 集群获取 deployment 信息

作者头像
老麦
发布2022-12-24 09:54:57
3600
发布2022-12-24 09:54:57
举报
文章被收录于专栏:Go与云原生Go与云原生

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

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

代码语言:javascript
复制
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 的版本

代码语言:javascript
复制
go get k8s.io/client-go@v0.21.4

go mod edit -replace=k8s.io/client-go=k8s.io/client-go@v0.21.4

连接集群并获取 deployment

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

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

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

pkg/k8s/cluster.go

代码语言:javascript
复制

// 从 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 的连接函数

代码语言:javascript
复制
var rootCmd = &cobra.Command{
	// .. 省略
	Run: func(cmd *cobra.Command, args []string) {
		// 连接 k3s
		k8s.Connent()
	},
}

运行结果如开篇所示。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-09-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 熊猫云原生Go 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 下载 client-go sdk
  • 连接集群并获取 deployment
  • 运行
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档