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

com.netflix.spectator.placeholders.PlaceholderFactory Maven / Gradle / Ivy

/*
 * Copyright 2014-2019 Netflix, Inc.
 *
 * 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.netflix.spectator.placeholders;

import com.netflix.spectator.api.Counter;
import com.netflix.spectator.api.DistributionSummary;
import com.netflix.spectator.api.Gauge;
import com.netflix.spectator.api.Registry;
import com.netflix.spectator.api.Timer;

/**
 * Factory for creating instances of activity based meters with placeholders in the
 * identifiers so that the final id can be resolved when the activity takes place.
 */
public interface PlaceholderFactory {

  /**
   * Create a new instance of the factory.
   *
   * @param registry
   *      the registry to use when creating ids
   */
  static PlaceholderFactory from(Registry registry) {
    return new DefaultPlaceholderFactory(registry);
  }

  /**
   * Creates an identifier with placeholders for a counter, timer, or distribution summary.
   *
   * @param name
   *     Description of the measurement that is being collected.
   * @return
   *     The newly created identifier.
   */
  PlaceholderId createId(String name);

  /**
   * Creates an identifier with placeholders for a counter, timer, or distribution summary.
   *
   * @param name
   *     Description of the measurement that is being collected.
   * @param tagFactories
   *     Other factories that can generate other dimensions that can be used to classify
   *     the measurement.
   * @return
   *     The newly created identifier.
   */
  PlaceholderId createId(String name, Iterable tagFactories);

  /**
   * Represents a value sampled at a given time.
   *
   * @param id
   *     Identifier created by a call to {@link #createId}
   */
  Gauge gauge(PlaceholderId id);

  /**
   * Measures the rate of some activity.  A counter is for continuously incrementing sources like
   * the number of requests that are coming into a server.
   *
   * @param id
   *     Identifier created by a call to {@link #createId}
   */
  Counter counter(PlaceholderId id);

  /**
   * Measures the rate and variation in amount for some activity. For example, it could be used to
   * get insight into the variation in response sizes for requests to a server.
   *
   * @param id
   *     Identifier created by a call to {@link #createId}
   */
  DistributionSummary distributionSummary(PlaceholderId id);

  /**
   * Measures the rate and time taken for short running tasks.
   *
   * @param id
   *     Identifier created by a call to {@link #createId}
   */
  Timer timer(PlaceholderId id);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy