I have followed the indication that adding the coda hale metrics library into the classpath would automatically autoconfigure the metrics.
That works, I get the injected metricRegistry bean.
However, how to I expose these new metrics in the /metrics endpoint?
Thanks!
That's not the way it's supposed to work. Codahale has some metric types that do not map to Spring Boot ones, so you are supposed to use the Codahale native APIs for reporting once you start collecting metrics that way. Boot is only providing the service abstraction for Gauge and Counter at that point.
UPDATE: Spring Boot also adds Codahale metrics to the /metrics endpoint since 1.2.0 (see
MetricRegistryMetricReader
).There's some integration magic accomplished by http://www.ryantenney.com/metrics-spring/ that wires codahale metrics into the actuator
/health
endpoint.With this dependency included,
you can "enableMetrics" in your application configuration
This allows you to time each request with the
@timed
annotation:and to have your other interactions with
MetricRegistry
aggregate into the actuator/health
endpoint.I've put together an example application which implements this integration:
https://github.com/benschw/consul-cluster-puppet/tree/master/demo
and written a more in depth tutorial here: http://txt.fliglio.com/2014/10/spring-boot-actuator/
I update a metrics histogram using spring-boot like this: