如何使用 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
}
我正在使用 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
}