diff options
author | Ivan Topolnak <ivantopo@gmail.com> | 2013-07-10 18:13:49 -0300 |
---|---|---|
committer | Ivan Topolnak <ivantopo@gmail.com> | 2013-07-10 18:13:49 -0300 |
commit | e8dd6c83986f1ecd2d717c39bffe900b23b68854 (patch) | |
tree | 43e0feaa42225a3770922a9366e126590225719a /src/main/scala/kamon/metric/Metrics.scala | |
parent | d1e22b3f446c89413c67421f19ab5215ebdfcd43 (diff) | |
download | Kamon-e8dd6c83986f1ecd2d717c39bffe900b23b68854.tar.gz Kamon-e8dd6c83986f1ecd2d717c39bffe900b23b68854.tar.bz2 Kamon-e8dd6c83986f1ecd2d717c39bffe900b23b68854.zip |
complete disaster, wip
Diffstat (limited to 'src/main/scala/kamon/metric/Metrics.scala')
-rw-r--r-- | src/main/scala/kamon/metric/Metrics.scala | 83 |
1 files changed, 82 insertions, 1 deletions
diff --git a/src/main/scala/kamon/metric/Metrics.scala b/src/main/scala/kamon/metric/Metrics.scala index 46fb2b64..352c51a0 100644 --- a/src/main/scala/kamon/metric/Metrics.scala +++ b/src/main/scala/kamon/metric/Metrics.scala @@ -1,8 +1,10 @@ package kamon.metric -import java.util.concurrent.TimeUnit +import java.util.concurrent.{ConcurrentHashMap, ConcurrentSkipListSet, TimeUnit} import com.codahale.metrics._ import akka.actor.ActorRef +import java.util.concurrent.atomic.AtomicReference +import com.codahale.metrics trait MetricDepot { def include(name: String, metric: Metric): Unit @@ -38,6 +40,11 @@ object Metrics extends MetricDepot { } } +object Watched { + case object Actor + case object Dispatcher +} + object MetricDirectory { def nameForDispatcher(actorSystem: String, dispatcher: String) = s"/ActorSystem/${actorSystem}/Dispatcher/${dispatcher}/" @@ -53,8 +60,82 @@ object MetricDirectory { } +} + + + +case class ActorSystemMetrics(actorSystemName: String) { + val dispatchers = new ConcurrentHashMap[String, DispatcherMetrics] + + def registerDispatcher(dispatcherName: String): Option[DispatcherMetricCollector] = { + ??? + } + +} + + + +case class DispatcherMetricCollector(activeThreadCount: ValueDistributionCollector, poolSize: ValueDistributionCollector, queueSize: ValueDistributionCollector) + + +trait ValueDistributionCollector { + def update(value: Long): Unit + def snapshot: HistogramLike } +trait HistogramLike { + def median: Long + def max: Long + def min: Long +} + +case class CodaHaleValueDistributionCollector extends ValueDistributionCollector { + private[this] val histogram = new Histogram(new metrics.ExponentiallyDecayingReservoir()) + + def median: Long = ??? + + def max: Long = ??? + + def min: Long = ??? + + def snapshot: HistogramLike = histogram.getSnapshot + + def update(value: Long) = histogram.update(value) +} + + + + + + + + + +/** + * Dispatcher Metrics that we care about currently with a histogram-like nature: + * - Work Queue Size + * - Total/Active Thread Count + */ + + + +import annotation.tailrec +import java.util.concurrent.atomic.AtomicReference + +object Atomic { + def apply[T]( obj : T) = new Atomic(new AtomicReference(obj)) + implicit def toAtomic[T]( ref : AtomicReference[T]) : Atomic[T] = new Atomic(ref) +} + +class Atomic[T](val atomic : AtomicReference[T]) { + @tailrec + final def update(f: T => T) : T = { + val oldValue = atomic.get() + val newValue = f(oldValue) + if (atomic.compareAndSet(oldValue, newValue)) newValue else update(f) + } + def get() = atomic.get() +}
\ No newline at end of file |