每当创建新的时间序列时,将prometheus计数器初始化为0

时间:2020-07-10 21:32:49

标签: counter prometheus prometheus-java

我正在研究一个用例,在该用例中,只要推送指标,就会创建新的时间序列。我正在使用计数器作为指标。我正在使用sum(increase(metric_name{_namespace_="elvis", Label1=~"d1", Label2=~"d2", Label3=~"d3"}[2m])) by (Label1, Label2, Label3),但是我的计数器被初始化为1而不是0,因此当我使用上述查询时,我看不到计数器从0跳到1的情况。我试图初始化我的计数器如下所示在注册时进行计数,但这无济于事。任何帮助将不胜感激

SimpleCollector counter = metricsMap.get(metricName);
        double cntrValue = 0d;
        if (counter == null) {
            synchronized (metricsMap) {
                counter = metricsMap.get(metricName);
                if (counter == null) {
                    counter = Counter.build()
                            .name(decorateMetricsName(metricName))
                            .help(decorateMetricsName(metricName) + " counter")
                            .register();      
                    metricsMap.put(metricName, counter);
                    cntrValue = ((Counter) counter.labels(getLabelValues(labels))).get();
                    logger.info( "Manifested Time Series with value");
                    logger.info( "Registered " + metricName);
                } else {
                    return (Counter)counter;
                }
            }
        }

0 个答案:

没有答案