- Added FindBugs checks to the build process.
- Fixed the catching of
Error
instances thrown during health checks. - Added
enable
static methods toCsvReporter
and changedCsvReporter(File, MetricsRegistry)
toCsvReporter(MetricsRegistry, File)
. - Slimmed down
InstrumentedEhcache
. - Hid the internals of
GangliaReporter
. - Hid the internals of
metrics-guice
. - Changed
metrics-httpclient
to consistently associate metrics with theorg.apache
class being extended. - Hid the internals of
metrics-httpclient
. - Rewrote
InstrumentedAppender
inmetrics-log4j
. It no longer forwards events to an appender. Instead, you can just attach it to your root logger to instrument logging. - Rewrote
InstrumentedAppender
inmetrics-logback
. No major API changes. - Fixed bugs with
@ExceptionMetered
-annotated resource methods inmetrics-jersey
. - Fixed bugs generating
Snapshot
instances from concurrently modified collections. - Fixed edge case in
MetricsServlet
's thread dumps where one thread could be missed. - Added
RatioGauge
andPercentGauge
. - Changed
InstrumentedQueuedThreadPool
'spercent-idle
gauge to be a ratio. - Decomposed
MetricsServlet
into a set of focused servlets:HealthCheckServlet
,MetricsServlet
,PingServlet
, andThreadDumpServlet
. The top-level servlet which provides the HTML menu page is nowAdminServlet
. - Added
metrics-spring
.
- Added absolute memory usage to
MetricsServlet
. - Extracted
@Timed
etc. tometrics-annotations
. - Added
metrics-jersey
, which provides a class allowing you to automatically instrument all@Timed
,@Metered
, and@ExceptionMetered
-annotated resource methods. - Moved all classes in
metrics-scala
fromcom.yammer.metrics
tocom.yammer.metrics.scala
. - Renamed
CounterMetric
toCounter
. - Renamed
GaugeMetric
toGauge
. - Renamed
HistogramMetric
toHistogram
. - Renamed
MeterMetric
toMeter
. - Renamed
TimerMetric
toTimer
. - Added
ToggleGauge
, which returns1
the first time it's called and0
every time after that. - Now licensed under Apache License 2.0.
- Converted
VirtualMachineMetrics
to a non-singleton class. - Removed
Utils
. - Removed deprecated constructors from
Meter
andTimer
. - Removed
LoggerMemoryLeakFix
. DeathRattleExceptionHandler
now logs to SLF4J, not syserr.- Added
MetricsRegistry#groupedMetrics()
. - Removed
Metrics#allMetrics()
. - Removed
Metrics#remove(MetricName)
. - Removed
MetricsRegistry#threadPools()
and#newMeterTickThreadPool()
and added#newScheduledThreadPool
. - Added
MetricsRegistry#shutdown()
. - Renamed
ThreadPools#shutdownThreadPools()
to#shutdown()
. - Replaced
HealthCheck
's abstractname
method with a required constructor parameter. HealthCheck#check()
is nowprotected
.- Moved
DeadlockHealthCheck
fromcom.yammer.metrics.core
tocom.yammer.metrics.utils
. - Added
HealthCheckRegistry#unregister(HealthCheck)
. - Fixed typo in
VirtualMachineMetrics
andMetricsServlet
:commited
tocommitted
. - Changed
MetricsRegistry#createName
toprotected
. - All metric types are created exclusively through
MetricsRegistry
now. Metrics.newJmxGauge
andMetricsRegistry.newJmxGauge
are deprecated.- Fixed heap metrics in
VirtualMachineMetrics
. - Added
Snapshot
, which calculates quantiles. - Renamed
Percentiled
toSampling
and droppedpercentile
andpercentiles
in favor of producingSnapshot
instances. This affects bothHistogram
andTimer
. - Renamed
Summarized
toSummarizable
. - Changed order of
CsvReporter
's construction parameters. - Renamed
VirtualMachineMetrics.GarbageCollector
toVirtualMachineMetrics.GarbageCollectorStats
. - Moved Guice/Servlet support from
metrics-servlet
tometrics-guice
. - Removed
metrics-aop
. - Removed
newJmxGauge
from bothMetrics
andMetricsRegistry
. Just useJmxGauge
. - Moved
JmxGauge
tocom.yammer.metrics.util
. - Moved
MetricPredicate
tocom.yammer.metrics.core
. - Moved
NameThreadFactory
intoThreadPools
and madeThreadPools
package-visible. - Removed
Timer#values()
,Histogram#values()
, andSample#values()
. UsegetSnapshot()
instead. - Removed
Timer#dump(File)
andHistogram#dump(File)
, andSample#dump(File)
. UseSnapshot#dump(File)
instead.
- Added
DeathRattleExceptionHandler
. - Fixed NPE in
VirtualMachineMetrics
. - Added decorators for connectors and thread pools in
metrics-jetty
. - Added
TimerMetric#time()
andTimerContext
. - Added a shorter factory method for millisecond/second timers.
- Switched tests to JUnit.
- Improved logging in
GangliaReporter
. - Improved random number generation for
UniformSample
. - Added
metrics-httpclient
for instrumenting Apache HttpClient 4.1. - Massively overhauled the reporting code.
- Added support for instrumented, non-
public
methods inmetrics-guice
. - Added
@ExceptionMetered
tometrics-guice
. - Added group prefixes to
GangliaReporter
. - Added
CvsReporter
, which outputs metric values to.csv
files. - Improved metric name sanitization in
GangliaReporter
. - Added
Metrics.shutdown()
and improved metrics lifecycle behavior. - Added
metrics-web
. - Upgraded to ehcache 2.5.0.
- Many, many refactorings.
metrics-servlet
now responds with501 Not Implememented
when no health checks have been registered.- Many internal refactorings for testability.
- Added histogram counts to
metrics-servlet
. - Fixed a race condition in
ExponentiallyDecayingSample
. - Added timezone and locale support to
ConsoleReporter
. - Added
metrics-aop
for Guiceless support of method annotations. - Added
metrics-jdbi
which adds instrumentation to JDBI. - Fixed NPE for metrics which belong to classes in the default package.
- Now deploying artifacts to Maven Central.
- Added an option message to successful health check results.
- Fixed locale issues in
GraphiteReporter
. - Added
GangliaReporter
. - Added per-HTTP method timers to
InstrumentedHandler
inmetrics-jetty
. - Fixed a thread pool leak for meters.
- Added
#dump(File)
toHistogramMetric
andTimerMetric
. - Upgraded to Jackson 1.9.x.
- Upgraded to slf4j 1.6.2.
- Upgraded to logback 0.9.30.
- Upgraded to ehcache 2.4.5.
- Surfaced
Metrics.removeMetric()
.
- Fixed a bug in GC monitoring.
- Fixed dependency scopes for
metrics-jetty
. - Added time and VM version to
vm
output ofMetricsServlet
. - Dropped
com.sun.mangement
-based GC instrumentation in favor of ajava.lang.management
-based one.getLastGcInfo
has a nasty native memory leak in it, plus it often returned incorrect data. - Upgraded to Jackson 1.8.5.
- Upgraded to Jetty 7.4.5.
- Added sanitization for metric names in
GraphiteReporter
. - Extracted out a
Clock
interface for timers for non-wall-clock timing. - Extracted out most of the remaining statics into
MetricsRegistry
andHealthCheckRegistry
. - Added an init parameter to
MetricsServlet
for disabling thejvm
section. - Added a Guice module for
MetricsServlet
. - Added dynamic metric names.
- Upgraded to ehcache 2.4.5.
- Upgraded to logback 0.9.29.
- Allowed for the removal of metrics.
- Added the ability to filter metrics exposed by a reporter to those which match a given predicate.
- Moved to Maven for a build system and extracted the Scala façade to a
metrics-scala
module which is now the only cross-built module. All other modules dropped the Scala version suffix in theirartifactId
s. - Fixed non-heap metric name in
GraphiteReporter
. - Fixed stability error in
GraphiteReporter
when dealing with unavilable servers. - Fixed error with anonymous, instrumented classes.
- Fixed error in
MetricsServlet
when a gauge throws an exception. - Fixed error with bogus GC run times.
- Link to the pretty JSON output from the
MetricsServlet
menu page. - Fixed potential race condition in histograms' variance calculations.
- Fixed memory pool reporting for the G1 collector.
- Fixed a bug in the intial startup phase of the
JmxReporter
. - Added
metrics-ehcache
, for the instrumentation ofEhcache
instances. - Fixed a typo in
metrics-jetty
'sInstrumentedHandler
. - Added name prefixes to
GraphiteReporter
. - Added JVM metrics reporting to
GraphiteReporter
. - Actually fixed
MetricsServlet
's links when the servlet has a non-root context path. - Now cross-building for Scala 2.9.0.
- Added
pretty
query parameter forMetricsServlet
to format the JSON object for human consumption. - Added
no-cache
headers to theMetricsServlet
responses.
- Upgraded to Jackson 1.7.6.
- Added a new instrumented Log4J appender.
- Added a new instrumented Logback appender. Thanks to Bruce Mitchener (@waywardmonkeys) for the patch.
- Added a new reporter for the Graphite aggregation system. Thanks to Mahesh Tiyyagura (@tmahesh) for the patch.
- Added scoped metric names.
- Added Scala 2.9.0.RC{2,3,4} as build targets.
- Added meters to Jetty handler for the percent of responses which have
4xx
or5xx
status codes. - Changed the Servlet API to be a
provided
dependency. Thanks to Mårten Gustafson (@chids) for the patch. - Separated project into modules:
metrics-core
: A dependency-less project with all the core metrics.metrics-graphite
: A reporter for the Graphite aggregation system.metrics-guice
: Guice AOP support.metrics-jetty
: An instrumented Jetty handler.metrics-log4j
: An instrumented Log4J appender.metrics-logback
: An instrumented Logback appender.metrics-servlet
: The Metrics servlet with context listener.
- Added thread state and deadlock detection metrics.
- Fix
VirtualMachineMetrics
' initialization. - Context path fixes for the servlet.
- Added the
@Gauge
annotation. - Big reworking of the exponentially-weighted moving average code for meters. Thanks to JD Maturen (@sku) and John Ewart (@johnewart) for pointing this out.
- Upgraded to Guice 3.0.
- Upgraded to Jackson 1.7.5.
- Upgraded to Jetty 7.4.0.
- Big rewrite of the servlet's thread dump code.
- Fixed race condition in
ExponentiallyDecayingSample
. Thanks to Martin Traverso (@martint) for the patch. - Lots of spelling fixes in Javadocs. Thanks to Bruce Mitchener (@waywardmonkeys) for the patch.
- Added Scala 2.9.0.RC1 as a build target. Thanks to Bruce Mitchener (@waywardmonkeys) for the patch.
- Patched a hilarious memory leak in
java.util.logging
.
- Added Guice AOP annotations.
- Added
HealthCheck#name()
. - Added
Metrics.newJmxGauge()
. - Moved health checks into
HealthChecks
. - Upgraded to Jackon 1.7.3 and Jetty 7.3.1.
- Added Guice AOP annotations:
@Timed
and@Metered
. - Added
HealthCheck#name()
. - Added
Metrics.newJmxGauge()
. - Moved health checks into
HealthChecks
. - Upgraded to Jackon 1.7.3 and Jetty 7.3.1.
- Fixed
JmxReporter
lag. - Added default arguments to timers and meters.
- Added default landing page to the servlet.
- Improved the performance of
ExponentiallyDecayingSample
. - Fixed an integer overflow bug in
UniformSample
. - Added linear scaling to
ExponentiallyDecayingSample
.
- Added histograms.
- Added biased sampling for timers.
- Added dumping of timer/histogram samples via the servlet.
- Added dependency on
jackon-mapper
. - Added classname filtering for the servlet.
- Added URI configuration for the servlet.
- Added
JettyHandler
. - Made the
Servlet
dependency optional.
- Fix
JmxReporter
initialization.
- Dropped
Counter#++
andCounter#--
. - Added
Timer#update
. - Upgraded to Jackson 1.7.0.
- Made JMX reporting implicit.
- Added health checks.
- Fixed thread names and some docs.
- Fixed a memory leak in
MeterMetric
.
- Total rewrite in Java.
- Added
median
toTimer
. - Added
p95
toTimer
(95th percentile). - Added
p98
toTimer
(98th percentile). - Added
p99
toTimer
(99th percentile).
- Now compiled exclusively for 2.8.0 final.
- Documentation fix.
- Added
TimedToggle
, which may or may not be useful at all. - Now cross-building for RC2 and RC3.
- Blank
Timer
s (i.e., those which have recorded no timings yet) no longer explode when asked for metrics for that which does not yet exist. - Nested classes, companion objects, and singletons don't have trailing
$
s messing up JMX's good looks.
- Fixed some issues with the implicit.ly plumbing.
- Tweaked the sample size for
Timer
, giving it 99.9% confidence level with a %5 margin of error (for a normally distributed variable, which it almost certainly isn't.) Sample#iterator
returns only the recorded data, not a bunch of zeros.- Moved units of
Timer
,Meter
, andLoadMeter
to their own attributes, which allows for easy export of Metrics data via JMX to things like Ganglia or whatever.
Timer
now uses Welford's algorithm for calculating running variance, which means no more hilariously wrong standard deviations (e.g.,NaN
).Timer
now supports+=(Long)
for pre-recorded, nanosecond-precision timings.
- changed
Sample
to use anAtomicReferenceArray
- Initial release