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

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
简介: 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的集群方式
相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
11天前
|
Kubernetes Cloud Native 云计算
云原生之旅:Kubernetes 集群的搭建与实践
【8月更文挑战第67天】在云原生技术日益成为IT行业焦点的今天,掌握Kubernetes已成为每个软件工程师必备的技能。本文将通过浅显易懂的语言和实际代码示例,引导你从零开始搭建一个Kubernetes集群,并探索其核心概念。无论你是初学者还是希望巩固知识的开发者,这篇文章都将为你打开一扇通往云原生世界的大门。
70 17
|
4天前
|
Kubernetes 应用服务中间件 nginx
搭建Kubernetes v1.31.1服务器集群,采用Calico网络技术
在阿里云服务器上部署k8s集群,一、3台k8s服务器,1个Master节点,2个工作节点,采用Calico网络技术。二、部署nginx服务到k8s集群,并验证nginx服务运行状态。
61 1
|
9天前
|
Kubernetes Cloud Native 微服务
微服务实践之使用 kube-vip 搭建高可用 Kubernetes 集群
微服务实践之使用 kube-vip 搭建高可用 Kubernetes 集群
30 1
|
9天前
|
负载均衡 应用服务中间件 nginx
基于Ubuntu-22.04安装K8s-v1.28.2实验(二)使用kube-vip实现集群VIP访问
基于Ubuntu-22.04安装K8s-v1.28.2实验(二)使用kube-vip实现集群VIP访问
26 1
|
14天前
|
Kubernetes Cloud Native Ubuntu
云原生之旅:Kubernetes集群搭建与应用部署
【8月更文挑战第65天】本文将带你进入云原生的世界,通过一步步指导如何在本地环境中搭建Kubernetes集群,并部署一个简单的应用。我们将使用Minikube和Docker作为工具,探索云原生技术的魅力所在。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和实践技巧。
|
20天前
|
关系型数据库 Go Docker
go连接postgre
go连接postgre
|
18天前
|
存储 Kubernetes 关系型数据库
阿里云ACK备份中心,K8s集群业务应用数据的一站式灾备方案
阿里云ACK备份中心,K8s集群业务应用数据的一站式灾备方案
|
1月前
|
存储 Kubernetes 负载均衡
CentOS 7.9二进制部署K8S 1.28.3+集群实战
本文详细介绍了在CentOS 7.9上通过二进制方式部署Kubernetes 1.28.3+集群的全过程,包括环境准备、组件安装、证书生成、高可用配置以及网络插件部署等关键步骤。
235 3
CentOS 7.9二进制部署K8S 1.28.3+集群实战
|
1月前
|
Kubernetes 负载均衡 前端开发
二进制部署Kubernetes 1.23.15版本高可用集群实战
使用二进制文件部署Kubernetes 1.23.15版本高可用集群的详细教程,涵盖了从环境准备到网络插件部署的完整流程。
67 2
二进制部署Kubernetes 1.23.15版本高可用集群实战
|
5天前
|
Kubernetes Cloud Native 流计算
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
29 0