RESTClient虽然可以操作k8s中的所有资源对象,但是使用起来确实比较复杂,需要配置的参数过于繁琐,所以为了更优雅的和APIserver
进行交互,则需要进一步封装。
ClientSet
是基于RESTClient
的封装,同时ClientSet
是使用预生成的API对象与APIServer
进行交互,这样方便我们进行二次开发。
ClientSet
是一组资源对象客户端的集合,比如操作pod、services等资源的CoreV1Client
,负责操作Deploy、DaemonSet等资源的AppsV1Client
等。通过这些资源对象客户端提供的操作方法,即可对K8s内置的资源对象进行Create、Update、Get、List、Delete等操作。
下面演示拿到pod列表的代码:
package main
import (
"context"
"fmt"
v1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/client-go/kubernetes"
"k8s.io/client-go/tools/clientcmd"
)
func main() {
//1.加载配置文件,生成config对象
config, err := clientcmd.BuildConfigFromFlags("", "F:\\GO\\src\\test\\config")
if err != nil {
fmt.Println(err)
}
//2.实例化clientset对象
clientset, err := kubernetes.NewForConfig(config)
if err != nil {
panic(err.Error())
}
//3.使用clientset去查看kube-system命名空间下的pod列表
pods, err := clientset.CoreV1().Pods("kube-system").List(context.TODO(), v1.ListOptions{})
if err != nil {
panic(err.Error())
}
//4.循环打印
for _, item := range pods.Items {
fmt.Println(item.Namespace, item.Name)
}
}