All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.google.monitoring.metrics.MetricRegistryImpl Maven / Gradle / Ivy

// Copyright 2017 Google LLC. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

package com.google.monitoring.metrics;

import static com.google.common.base.Preconditions.checkState;

import com.google.common.annotations.VisibleForTesting;
import com.google.common.base.Supplier;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap;
import com.google.common.collect.ImmutableSet;
import com.google.errorprone.annotations.CanIgnoreReturnValue;
import java.util.concurrent.ConcurrentHashMap;
import java.util.logging.Logger;
import javax.annotation.concurrent.ThreadSafe;

/** A singleton registry of {@link Metric}s. */
@ThreadSafe
public final class MetricRegistryImpl implements MetricRegistry {

  private static final Logger logger = Logger.getLogger(MetricRegistryImpl.class.getName());
  private static final MetricRegistryImpl INSTANCE = new MetricRegistryImpl();

  /** The canonical registry for metrics. The map key is the metric name. */
  private final ConcurrentHashMap> registeredMetrics = new ConcurrentHashMap<>();

  /**
   * Production code must use {@link #getDefault}, since this returns the {@link MetricRegistry}
   * that {@link MetricReporter} uses. Test code that does not use {@link MetricReporter} can use
   * this constructor to get an isolated instance of the registry.
   */
  @VisibleForTesting
  public MetricRegistryImpl() {}

  public static MetricRegistryImpl getDefault() {
    return INSTANCE;
  }

  /**
   * Creates a new event metric.
   *
   * 

Note that the order of the labels is significant. */ @Override public EventMetric newEventMetric( String name, String description, String valueDisplayName, ImmutableSet labels, DistributionFitter distributionFitter) { EventMetric metric = new EventMetric(name, description, valueDisplayName, distributionFitter, labels); registerMetric(name, metric); logger.info("Registered new event metric: " + name); return metric; } /** * Creates a new gauge metric. * *

Note that the order of the labels is significant. */ @Override @CanIgnoreReturnValue public Metric newGauge( String name, String description, String valueDisplayName, ImmutableSet labels, Supplier, V>> metricCallback, Class valueClass) { VirtualMetric metric = new VirtualMetric<>( name, description, valueDisplayName, labels, metricCallback, valueClass); registerMetric(name, metric); logger.info("Registered new callback metric: " + name); return metric; } /** * Creates a new settable metric. * *

Note that the order of the labels is significant. */ @Override public SettableMetric newSettableMetric( String name, String description, String valueDisplayName, ImmutableSet labels, Class valueClass) { StoredMetric metric = new StoredMetric<>(name, description, valueDisplayName, labels, valueClass); registerMetric(name, metric); logger.info("Registered new stored metric: " + name); return metric; } /** * Creates a new incrementable metric. * *

Note that the order of the labels is significant. */ @Override public IncrementableMetric newIncrementableMetric( String name, String description, String valueDisplayName, ImmutableSet labels) { Counter metric = new Counter(name, description, valueDisplayName, labels); registerMetric(name, metric); logger.info("Registered new counter: " + name); return metric; } @Override public ImmutableList> getRegisteredMetrics() { return ImmutableList.copyOf(registeredMetrics.values()); } /** * Unregisters a metric. * *

This is a no-op if the metric is not already registered. * *

{@link MetricWriter} implementations should not send unregistered metrics on subsequent * write intervals. */ @VisibleForTesting public void unregisterMetric(String name) { registeredMetrics.remove(name); logger.info("Unregistered metric: " + name); } @VisibleForTesting public void unregisterAllMetrics() { registeredMetrics.clear(); } /** Registers a metric. */ @VisibleForTesting void registerMetric(String name, Metric metric) { Metric previousMetric = registeredMetrics.putIfAbsent(name, metric); checkState(previousMetric == null, "Duplicate metric of same name: %s", name); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy