当前位置: 首页 > news >正文

Koordinator-Metric查询

以CollectAllPodMetricsLast()举例,看看koordinator怎样使用tsdb进行查询。

CollectAllPodMetricsLast()

  • GenerateQueryParamsLast()传入metric采集间隔2倍时间
  • 调用CollectAllPodMetrics()
func CollectAllPodMetricsLast(statesInformer statesinformer.StatesInformer, metricCache metriccache.MetricCache,
    metricResource metriccache.MetricResource, metricCollectInterval time.Duration) map[string]float64 {
    queryParam := GenerateQueryParamsLast(metricCollectInterval * 2)
    return CollectAllPodMetrics(statesInformer, metricCache, *queryParam, metricResource)
}

GenerateQueryParamsLast()

  • end为当前时间
  • start为传入offset
  • 构造metriccache.QueryParam,参数aggregate为Last(最近)
func GenerateQueryParamsLast(windowDuration time.Duration) *metriccache.QueryParam {
    end := time.Now()
    start := end.Add(-windowDuration)
    queryParam := &metriccache.QueryParam{
        Aggregate: metriccache.AggregationTypeLast,
        Start:     &start,
        End:       &end,
    }
    return queryParam
}

CollectAllPodMetrics()

  • 构建BuildQueryMeta
  • 调用CollectPodMetric()
    • 参数:metric缓存、queryMeta、startTime、endTime。
    • 获取结果后,设置aggregate
func CollectAllPodMetrics(statesInformer statesinformer.StatesInformer, metricCache metriccache.MetricCache,
    queryParam metriccache.QueryParam, metricResource metriccache.MetricResource) map[string]float64 {
    podsMeta := statesInformer.GetAllPods()
    podsMetrics := make(map[string]float64)
    for _, podMeta := range podsMeta {
        queryMeta, err := metricResource.BuildQueryMeta(metriccache.MetricPropertiesFunc.Pod(string(podMeta.Pod.UID)))
        if err != nil {
            klog.Warningf("build pod %s/%s query meta failed, kind: %s, error: %v", podMeta.Pod.Namespace, podMeta.Pod.Name, queryMeta.GetKind(), err)
            continue
        }
        podQueryResult, err := CollectPodMetric(metricCache, queryMeta, *queryParam.Start, *queryParam.End)
        if err != nil {
            klog.Warningf("query pod %s/%s metric failed, kind: %s, error: %v", podMeta.Pod.Namespace, podMeta.Pod.Name, queryMeta.GetKind(), err)
            continue
        }
        if podQueryResult.Count() == 0 {
            klog.V(5).Infof("query pod %s/%s metric is empty, kind: %s", podMeta.Pod.Namespace, podMeta.Pod.Name, queryMeta.GetKind())
            continue
        }
        value, err := podQueryResult.Value(queryParam.Aggregate)
        if err != nil {
    
http://www.dtcms.com/a/98403.html

相关文章:

  • Python3基础库入门(个人学习用)
  • [ C语言 ] | 从0到1?
  • Redis设计与实现-哨兵
  • 分销商城小程序开发六大核心功能详解
  • 用react实现router路由
  • C++ 中名字的作用域、概念、嵌套与实践(十八)
  • Java基础-22-基本语法-实体类
  • 【MySQL篇】事务管理,事务的特性及深入理解隔离级别
  • Unity功能模块一对话系统(5)-完善对话流程及功能
  • Python针对大规模数据使用”sys模块加速I/O操作“:
  • 21天Python计划:函数简单介绍
  • PCBB印刷电路板缺陷检测YOLO数据集分享
  • LeetCode hot 100—两两交换链表中的节点
  • Redis场景问题1:缓存穿透
  • 用python压缩图片大小
  • 算法-广度优先搜索
  • WSL系统找不到指定的文件
  • 接口自动化——初识pytest
  • (头歌作业—python)3.2 个人所得税计算器(project)
  • 智能发光斑马线:点亮城市道路安全之光
  • DDR(Double Data Rate)详解
  • 云边端协同
  • vue 脚手架解决跨域问题
  • 2022年12月青少年软件编程(图形化)等级考试三级编程题
  • 在树莓派5(8G版)上运行Ollama + LLM
  • NG-ZORRO中tree组件的getCheckedNodeList怎么使用
  • 26考研——排序_选择排序_选择排序的基本思想 简单选择排序(8)
  • 每天一篇目标检测文献(六)——Part One
  • 小林coding-12道Spring面试题
  • 自然语言处理(17:(第五章2.)梯度消失和LSTM(详细拆解))