client-go连接kubernetes集群-connect and list

简介: kubernetes的基本应用的算是能入门了。但是基于各种客户端操作kubernetes集群还是没有深入玩过,最近一段时间入门了一下goland,就拿client-go深入体验一下kubernetes集群的基本操作,当然了最后能更深入一下跟gin框架结合了就好了......算是练手入门

背景:

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

开发环境Goland2022.1

上手client-go连接kubernetes集群

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

创建好目录结构如下:

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

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

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

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下:

注:当然了很多自建的集群填写的都是内网的方式,可以通过代理或者其他方式连接集群

第一个例子打印一下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

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"

同理,下面打印一下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)


}

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

强调的:

  1. CoreV1 AppV1
  2. context的用法
  3. metav1
  4. 其他连接kubernetes的集群方式
相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
云原生实践公开课
课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
3天前
|
存储 运维 Kubernetes
Kubernetes 集群的持续性能优化实践
【4月更文挑战第22天】在动态且复杂的微服务架构中,确保 Kubernetes 集群的高性能运行是至关重要的。本文将深入探讨针对 Kubernetes 集群性能优化的策略与实践,从节点资源配置、网络优化到应用部署模式等多个维度展开,旨在为运维工程师提供一套系统的性能调优方法论。通过实际案例分析与经验总结,读者可以掌握持续优化 Kubernetes 集群性能的有效手段,以适应不断变化的业务需求和技术挑战。
16 4
|
2月前
|
Kubernetes Ubuntu 应用服务中间件
在Ubuntu22.04 LTS上搭建Kubernetes集群
在Ubuntu22.04.4上安装Kubernetes v1.28.7,步骤超详细
336 1
在Ubuntu22.04 LTS上搭建Kubernetes集群
|
1月前
|
Prometheus 监控 Kubernetes
Kubernetes 集群监控与日志管理实践
【2月更文挑战第29天】 在微服务架构日益普及的当下,Kubernetes 已成为容器编排的事实标准。然而,随着集群规模的扩大和业务复杂度的提升,有效的监控和日志管理变得至关重要。本文将探讨构建高效 Kubernetes 集群监控系统的策略,以及实施日志聚合和分析的最佳实践。通过引入如 Prometheus 和 Fluentd 等开源工具,我们旨在为运维专家提供一套完整的解决方案,以保障系统的稳定性和可靠性。
|
21天前
|
数据库 存储 监控
什么是 SAP HANA 内存数据库 的 Delta Storage
什么是 SAP HANA 内存数据库 的 Delta Storage
16 0
什么是 SAP HANA 内存数据库 的 Delta Storage
|
28天前
|
Kubernetes 流计算 Perl
在Rancher K8s上部署Flink时,TaskManager连接不上并不断重启可能是由多种原因导致的
在Rancher K8s上部署Flink时,TaskManager连接不上并不断重启可能是由多种原因导致的
34 7
|
2天前
|
存储 运维 Kubernetes
Kubernetes 集群的监控与维护策略
【4月更文挑战第23天】 在微服务架构日益盛行的当下,容器编排工具如 Kubernetes 成为了运维工作的重要环节。然而,随着集群规模的增长和复杂性的提升,如何确保 Kubernetes 集群的高效稳定运行成为了一大挑战。本文将深入探讨 Kubernetes 集群的监控要点、常见问题及解决方案,并提出一系列切实可行的维护策略,旨在帮助运维人员有效管理和维护 Kubernetes 环境,保障服务的持续可用性和性能优化。
|
11天前
|
Kubernetes 搜索推荐 Docker
使用 kubeadm 部署 Kubernetes 集群(二)k8s环境安装
使用 kubeadm 部署 Kubernetes 集群(二)k8s环境安装
53 17
|
23天前
|
消息中间件 Kubernetes Kafka
Terraform阿里云创建资源1分钟创建集群一键发布应用Terraform 创建 Kubernetes 集群
Terraform阿里云创建资源1分钟创建集群一键发布应用Terraform 创建 Kubernetes 集群
16 0
|
24天前
|
Kubernetes 安全 网络安全
搭建k8s集群kubeadm搭建Kubernetes二进制搭建Kubernetes集群
搭建k8s集群kubeadm搭建Kubernetes二进制搭建Kubernetes集群
106 0
|
1月前
|
Kubernetes Cloud Native Docker
【云原生】kubeadm快速搭建K8s集群Kubernetes1.19.0
Kubernetes 是一个开源平台,用于管理容器化工作负载和服务,提供声明式配置和自动化。源自 Google 的大规模运维经验,它拥有广泛的生态支持。本文档详细介绍了 Kubernetes 集群的搭建过程,包括服务器配置、Docker 和 Kubernetes 组件的安装,以及 Master 和 Node 的部署。此外,还提到了使用 Calico 作为 CNI 网络插件,并提供了集群功能的测试步骤。
219 0

推荐镜像

更多