登录
首页 >  Golang >  Go问答

使用 Go 客户端获取 Kubernetes 中 Pod 的当前资源使用情况

来源:Golang技术栈

时间:2023-04-28 11:46:23 454浏览 收藏

偷偷努力,悄无声息地变强,然后惊艳所有人!哈哈,小伙伴们又来学习啦~今天我将给大家介绍《使用 Go 客户端获取 Kubernetes 中 Pod 的当前资源使用情况》,这篇文章主要会讲到golang等等知识点,不知道大家对其都有多少了解,下面我们就一起来看一吧!当然,非常希望大家能多多评论,给出合理的建议,我们一起学习,一起进步!

问题内容

kubernetes go 客户端有很多方法,我找不到如何获取特定(或所有 pod)的当前 CPU 和 RAM 使用情况。

有人能告诉我需要调用哪些方法来获取 pod 和节点的当前使用情况吗?

我的节点列表:

nodes, err := clientset.CoreV1().Nodes().List(metav1.ListOptions{})

Kubernetes Go 客户端:https ://github.com/kubernetes/client- go

指标包:https ://github.com/kubernetes/kubernetes/tree/master/staging/src/k8s.io/metrics

据我所知,指标服务器实现了 Kubernetes 指标包,以便从 pod 和节点获取资源使用情况,但我不知道他们在哪里以及如何做到这一点:[https ://github.com/kubernetes-incubator /指标服务器](https://github.com/kubernetes- incubator/metrics-server)

正确答案

go-client 不支持度量类型是正确的,但是在度量包中有一个预生成的客户端,可用于获取度量对象并立即将它们分配给适当的结构。您首先需要做的唯一一件事是生成配置并将其传递给指标客户端。所以一个简单的指标客户端看起来像这样:

package main


import (
    "k8s.io/client-go/tools/clientcmd"
    metrics "k8s.io/metrics/pkg/client/clientset/versioned"
    metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)



func main() {
    var kubeconfig, master string //empty, assuming inClusterConfig
    config, err := clientcmd.BuildConfigFromFlags(master, kubeconfig)
    if err != nil{
        panic(err)
    }

    mc, err := metrics.NewForConfig(config)
    if err != nil {
        panic(err)
    }

    mc.MetricsV1beta1().NodeMetricses().Get("your node name", metav1.GetOptions{})
    mc.MetricsV1beta1().NodeMetricses().List(metav1.ListOptions{})
    mc.MetricsV1beta1().PodMetricses(metav1.NamespaceAll).List(metav1.ListOptions{})
    mc.MetricsV1beta1().PodMetricses(metav1.NamespaceAll).Get("your pod name", metav1.GetOptions{})
}

来自 metric 客户端的上述每个方法都会返回一个适当的结构(您可以在此处查看)和​​一个错误(如果有),您应该根据您的要求对其进行处理。

本篇关于《使用 Go 客户端获取 Kubernetes 中 Pod 的当前资源使用情况》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

声明:本文转载于:Golang技术栈 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>