Loading

k8s_client-go 构建客户端的几种方式

kubernetes client-go 构建客户端的几种方式

package callk8s

import (
	"context"
	"log"

	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
	"k8s.io/client-go/kubernetes"
	"k8s.io/client-go/rest"
	"k8s.io/client-go/tools/clientcmd"
)

type KConf struct {
	Configure string
	C         *kubernetes.Clientset
	NameSpace string
}

// NewCli 从指定配置文件中加载配置
func NewCli(confDir, namespace string) (*KConf, error) {
	var kconf KConf
	kconf.Configure = confDir
	kconf.NameSpace = namespace
	config, err := clientcmd.BuildConfigFromFlags("", kconf.Configure)
	if err != nil {
		log.Println(err)
		return &kconf, err
	}
	c, err := kubernetes.NewForConfig(config)
	if err != nil {
		log.Println(err)
		return &kconf, err
	}
	kconf.C = c
	return &kconf, nil

}

// NewFromBytes 从二进制内存中加载配置
func NewFromBytes(configBytes []byte, namespace string) (*KConf, error) {
	var kconf KConf
	nccfb, err := clientcmd.NewClientConfigFromBytes(configBytes)
	if err != nil {
		log.Println("Err: ", err)
		return &kconf, err
	}
	tmpf, err := nccfb.ClientConfig()
	if err != nil {
		log.Println("Err: ", err)
		return &kconf, err
	}
	kconf.C, err = kubernetes.NewForConfig(tmpf)
	if err != nil {
		log.Println("Err: ", err)
		return &kconf, err
	}
	return &kconf, nil
}

// RestClientFromSA 从pod sa 中获取 ,/var/run/secerts/kubernetes.io/serviceaccount/token
func RestClientFromSA() (*KConf, error) {
	var kconf KConf
	config, err := rest.InClusterConfig()
	if err != nil {
		log.Printf("Err: %v", err)
		return &kconf, err
	}
	kconf.C, err = kubernetes.NewForConfig(config)
	if err != nil {
		return &kconf, err
	}
	return &kconf, nil
}
posted @ 2024-01-22 11:45  尚墨  阅读(31)  评论(0编辑  收藏  举报