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 {
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值