nl.grons.metrics

scala

package scala

Visibility
  1. Public
  2. All

Type Members

  1. trait BaseBuilder extends AnyRef

  2. trait CheckedBuilder extends BaseBuilder

    The mixin trait for creating a class which creates health checks.

  3. class Counter extends AnyRef

    A Scala facade class for DropwizardCounter.

  4. trait FutureMetrics extends AnyRef

    Provides timing of future executions.

  5. class Gauge[T] extends AnyRef

    A Scala facade class for DropwizardGauge.

  6. class HdrMetricBuilder extends MetricBuilder

    An alternative metric builder that creates Histograms and Timers with Reservoirs from the HdrHistogram library.

    An alternative metric builder that creates Histograms and Timers with Reservoirs from the HdrHistogram library.

    See the the manual for more instructions on using hdrhistogram.

  7. sealed trait HealthCheckMagnet extends AnyRef

    Magnet for the checker.

  8. class Histogram extends AnyRef

    A Scala facade class for DropwizardHistogram.

  9. trait InstrumentedBuilder extends BaseBuilder

    The mixin trait for creating a class which is instrumented with metrics.

    The mixin trait for creating a class which is instrumented with metrics.

    Use it as follows:

    object Application {
      // The application wide metrics registry.
      val metricRegistry = new com.codahale.metrics.MetricRegistry()
    }
    trait Instrumented extends InstrumentedBuilder {
      val metricRegistry = Application.metricRegistry
    }
    
    class Example(db: Database) extends Instrumented {
      private[this] val loading = metrics.timer("loading")
    
      def loadStuff(): Seq[Row] = loading.time {
        db.fetchRows()
      }
    }

    It is also possible to override the metric base name. For example:

    class Example(db: Database) extends Instrumented {
      override lazy val metricBaseName = MetricName("Overridden.Base.Name")
      private[this] val loading = metrics.timer("loading")
    
      def loadStuff(): Seq[Row] = loading.time {
        db.fetchRows()
      }
    }

    If you want to use hdrhistograms, you can override the metric builder as follows:

    trait Instrumented extends InstrumentedBuilder {
      override lazy protected val metricBuilder = new HdrMetricBuilder(metricBaseName, metricRegistry, false)
      val metricRegistry = Application.metricRegistry
    }

    See the the manual for more instructions on using hdrhistogram.

  10. class Meter extends AnyRef

    A Scala facade class for DropwizardMeter.

    A Scala facade class for DropwizardMeter.

    Example usage:

    class Example(val db: Db) extends Instrumented {
      private[this] val rowsLoadedMeter = metrics.meter("rowsLoaded")
    
      def load(id: Long): Seq[Row] = {
        val rows = db.load(id)
        rowsLoaded.mark(rows.size)
        rows
      }
    }
  11. class MetricBuilder extends AnyRef

    Builds and registering metrics.

  12. class MetricName extends AnyRef

    The (base)name of a metric.

    The (base)name of a metric.

    Constructed via the companion object, e.g. MetricName(getClass, "requests").

  13. class Timer extends AnyRef

    A Scala facade class for DropwizardTimer.

    A Scala facade class for DropwizardTimer.

    Example usage:

    class Example(val db: Db) extends Instrumented {
      private[this] val loadTimer = metrics.timer("load")
    
      def load(id: Long) = loadTimer.time {
        db.load(id)
      }
    }

Value Members

  1. object Gauge

  2. object HealthCheckMagnet

  3. object MetricName

Ungrouped