如何使用 go-lang 在 Kubernetes 中提取活动的 HPA

How to extract the active HPA in Kubernetes using go-lang

我正在使用 kube 配置文件通过 go-lang 获取 pod CPU 和 MEM 数据。我坚持要获取 HPA 详细信息,即我正在尝试编写“kubectl get hpa”的等效项,因此我可以知道我是否已将 hpa 应用于已知服务。

非常感谢任何帮助。

到目前为止我已经尝试了以下方法。

kubeClient "k8s.io/client-go/kubernetes/typed/autoscaling/v1"
hpaWatch, err := kubeClient.AutoscalingV1().HorizontalPodAutoscalers("default").Watch(metav1.ListOptions{})

但这不起作用。

这是您应该使用的行:

hpas, err := clientset.AutoscalingV1().HorizontalPodAutoscalers("default").List(context.TODO(), metav1.ListOptions{})

以下是列出 HPA 的完整且有效的示例。你应该可以 copy-paste 它和 运行 它。

已通过 client-go@0.19.0 测试。

package main

import (
    "context"
    "flag"
    "fmt"
    "os"
    "path/filepath"
    "time"

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

func main() {
    var kubeconfig *string
    if home := 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()

    // use the current context in kubeconfig
    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())
    }
    for {
        hpas, err := clientset.AutoscalingV1().HorizontalPodAutoscalers("default").List(context.TODO(), metav1.ListOptions{})
        if err != nil {
            panic(err.Error())
        }

        for _, hpa := range hpas.Items {
            fmt.Printf("%q\n", hpa.GetName())
        }

        time.Sleep(10 * time.Second)
    }
}

func homeDir() string {
    if h := os.Getenv("HOME"); h != "" {
        return h
    }
    return os.Getenv("USERPROFILE") // windows
}