Rename CodahaleMetricWriter
Deprecate CodahaleMetricWriter and create DropwizardMetricWriter to reflect the renamed project. Fixes gh-2442
This commit is contained in:
parent
e1a80fa496
commit
c02b99b257
|
|
@ -29,10 +29,10 @@ import org.springframework.boot.actuate.metrics.export.Exporter;
|
||||||
import org.springframework.boot.actuate.metrics.reader.MetricRegistryMetricReader;
|
import org.springframework.boot.actuate.metrics.reader.MetricRegistryMetricReader;
|
||||||
import org.springframework.boot.actuate.metrics.repository.InMemoryMetricRepository;
|
import org.springframework.boot.actuate.metrics.repository.InMemoryMetricRepository;
|
||||||
import org.springframework.boot.actuate.metrics.repository.MetricRepository;
|
import org.springframework.boot.actuate.metrics.repository.MetricRepository;
|
||||||
import org.springframework.boot.actuate.metrics.writer.CodahaleMetricWriter;
|
|
||||||
import org.springframework.boot.actuate.metrics.writer.CompositeMetricWriter;
|
import org.springframework.boot.actuate.metrics.writer.CompositeMetricWriter;
|
||||||
import org.springframework.boot.actuate.metrics.writer.DefaultCounterService;
|
import org.springframework.boot.actuate.metrics.writer.DefaultCounterService;
|
||||||
import org.springframework.boot.actuate.metrics.writer.DefaultGaugeService;
|
import org.springframework.boot.actuate.metrics.writer.DefaultGaugeService;
|
||||||
|
import org.springframework.boot.actuate.metrics.writer.DropwizardMetricWriter;
|
||||||
import org.springframework.boot.actuate.metrics.writer.MessageChannelMetricWriter;
|
import org.springframework.boot.actuate.metrics.writer.MessageChannelMetricWriter;
|
||||||
import org.springframework.boot.actuate.metrics.writer.MetricWriter;
|
import org.springframework.boot.actuate.metrics.writer.MetricWriter;
|
||||||
import org.springframework.boot.actuate.metrics.writer.MetricWriterMessageHandler;
|
import org.springframework.boot.actuate.metrics.writer.MetricWriterMessageHandler;
|
||||||
|
|
@ -83,7 +83,7 @@ import com.codahale.metrics.MetricRegistry;
|
||||||
* @see CounterService
|
* @see CounterService
|
||||||
* @see MetricWriter
|
* @see MetricWriter
|
||||||
* @see InMemoryMetricRepository
|
* @see InMemoryMetricRepository
|
||||||
* @see CodahaleMetricWriter
|
* @see DropwizardMetricWriter
|
||||||
* @see Exporter
|
* @see Exporter
|
||||||
*
|
*
|
||||||
* @author Dave Syer
|
* @author Dave Syer
|
||||||
|
|
@ -153,7 +153,7 @@ public class MetricRepositoryAutoConfiguration {
|
||||||
|
|
||||||
@Configuration
|
@Configuration
|
||||||
@ConditionalOnClass(MetricRegistry.class)
|
@ConditionalOnClass(MetricRegistry.class)
|
||||||
static class CodahaleMetricRegistryConfiguration {
|
static class DropwizardMetricRegistryConfiguration {
|
||||||
|
|
||||||
@Bean
|
@Bean
|
||||||
@ConditionalOnMissingBean
|
@ConditionalOnMissingBean
|
||||||
|
|
@ -162,8 +162,8 @@ public class MetricRepositoryAutoConfiguration {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Bean
|
@Bean
|
||||||
public CodahaleMetricWriter codahaleMetricWriter(MetricRegistry metricRegistry) {
|
public DropwizardMetricWriter dropwizardMetricWriter(MetricRegistry metricRegistry) {
|
||||||
return new CodahaleMetricWriter(metricRegistry);
|
return new DropwizardMetricWriter(metricRegistry);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Bean
|
@Bean
|
||||||
|
|
@ -175,7 +175,7 @@ public class MetricRepositoryAutoConfiguration {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Bean
|
@Bean
|
||||||
public PublicMetrics codahalePublicMetrics(MetricRegistry metricRegistry) {
|
public PublicMetrics dropwizardPublicMetrics(MetricRegistry metricRegistry) {
|
||||||
MetricRegistryMetricReader reader = new MetricRegistryMetricReader(
|
MetricRegistryMetricReader reader = new MetricRegistryMetricReader(
|
||||||
metricRegistry);
|
metricRegistry);
|
||||||
return new MetricReaderPublicMetrics(reader);
|
return new MetricReaderPublicMetrics(reader);
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2012-2014 the original author or authors.
|
* Copyright 2012-2015 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
|
@ -16,10 +16,6 @@
|
||||||
|
|
||||||
package org.springframework.boot.actuate.metrics.writer;
|
package org.springframework.boot.actuate.metrics.writer;
|
||||||
|
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
|
||||||
import java.util.concurrent.ConcurrentMap;
|
|
||||||
import java.util.concurrent.TimeUnit;
|
|
||||||
|
|
||||||
import org.springframework.boot.actuate.metrics.Metric;
|
import org.springframework.boot.actuate.metrics.Metric;
|
||||||
|
|
||||||
import com.codahale.metrics.Counter;
|
import com.codahale.metrics.Counter;
|
||||||
|
|
@ -46,90 +42,17 @@ import com.codahale.metrics.Timer;
|
||||||
* </ul>
|
* </ul>
|
||||||
*
|
*
|
||||||
* @author Dave Syer
|
* @author Dave Syer
|
||||||
|
* @deprecated since 1.2.2 in favor of {@link DropwizardMetricWriter}
|
||||||
*/
|
*/
|
||||||
public class CodahaleMetricWriter implements MetricWriter {
|
@Deprecated
|
||||||
|
public class CodahaleMetricWriter extends DropwizardMetricWriter {
|
||||||
private final MetricRegistry registry;
|
|
||||||
|
|
||||||
private final ConcurrentMap<String, Object> gaugeLocks = new ConcurrentHashMap<String, Object>();
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a new {@link CodahaleMetricWriter} instance.
|
* Create a new {@link DropwizardMetricWriter} instance.
|
||||||
* @param registry the underlying metric registry
|
* @param registry the underlying metric registry
|
||||||
*/
|
*/
|
||||||
public CodahaleMetricWriter(MetricRegistry registry) {
|
public CodahaleMetricWriter(MetricRegistry registry) {
|
||||||
this.registry = registry;
|
super(registry);
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void increment(Delta<?> delta) {
|
|
||||||
String name = delta.getName();
|
|
||||||
long value = delta.getValue().longValue();
|
|
||||||
if (name.startsWith("meter")) {
|
|
||||||
Meter meter = this.registry.meter(name);
|
|
||||||
meter.mark(value);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
Counter counter = this.registry.counter(name);
|
|
||||||
counter.inc(value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void set(Metric<?> value) {
|
|
||||||
String name = value.getName();
|
|
||||||
if (name.startsWith("histogram")) {
|
|
||||||
long longValue = value.getValue().longValue();
|
|
||||||
Histogram metric = this.registry.histogram(name);
|
|
||||||
metric.update(longValue);
|
|
||||||
}
|
|
||||||
else if (name.startsWith("timer")) {
|
|
||||||
long longValue = value.getValue().longValue();
|
|
||||||
Timer metric = this.registry.timer(name);
|
|
||||||
metric.update(longValue, TimeUnit.MILLISECONDS);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
final double gauge = value.getValue().doubleValue();
|
|
||||||
// Ensure we synchronize to avoid another thread pre-empting this thread after
|
|
||||||
// remove causing an error in CodaHale metrics
|
|
||||||
// NOTE: CodaHale provides no way to do this atomically
|
|
||||||
synchronized (getGuageLock(name)) {
|
|
||||||
this.registry.remove(name);
|
|
||||||
this.registry.register(name, new SimpleGauge(gauge));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private Object getGuageLock(String name) {
|
|
||||||
Object lock = this.gaugeLocks.get(name);
|
|
||||||
if (lock == null) {
|
|
||||||
Object newLock = new Object();
|
|
||||||
lock = this.gaugeLocks.putIfAbsent(name, newLock);
|
|
||||||
lock = (lock == null ? newLock : lock);
|
|
||||||
}
|
|
||||||
return lock;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void reset(String metricName) {
|
|
||||||
this.registry.remove(metricName);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Simple {@link Gauge} implementation to {@literal double} value.
|
|
||||||
*/
|
|
||||||
private static class SimpleGauge implements Gauge<Double> {
|
|
||||||
|
|
||||||
private final double value;
|
|
||||||
|
|
||||||
private SimpleGauge(double value) {
|
|
||||||
this.value = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Double getValue() {
|
|
||||||
return this.value;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,135 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2012-2014 the original author or authors.
|
||||||
|
*
|
||||||
|
* 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 org.springframework.boot.actuate.metrics.writer;
|
||||||
|
|
||||||
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
|
import java.util.concurrent.ConcurrentMap;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
|
import org.springframework.boot.actuate.metrics.Metric;
|
||||||
|
|
||||||
|
import com.codahale.metrics.Counter;
|
||||||
|
import com.codahale.metrics.Gauge;
|
||||||
|
import com.codahale.metrics.Histogram;
|
||||||
|
import com.codahale.metrics.Meter;
|
||||||
|
import com.codahale.metrics.MetricRegistry;
|
||||||
|
import com.codahale.metrics.Timer;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A {@link MetricWriter} that send data to a Codahale {@link MetricRegistry} based on a
|
||||||
|
* naming convention:
|
||||||
|
*
|
||||||
|
* <ul>
|
||||||
|
* <li>Updates to {@link #increment(Delta)} with names in "meter.*" are treated as
|
||||||
|
* {@link Meter} events</li>
|
||||||
|
* <li>Other deltas are treated as simple {@link Counter} values</li>
|
||||||
|
* <li>Inputs to {@link #set(Metric)} with names in "histogram.*" are treated as
|
||||||
|
* {@link Histogram} updates</li>
|
||||||
|
* <li>Inputs to {@link #set(Metric)} with names in "timer.*" are treated as {@link Timer}
|
||||||
|
* updates</li>
|
||||||
|
* <li>Other metrics are treated as simple {@link Gauge} values (single valued
|
||||||
|
* measurements of type double)</li>
|
||||||
|
* </ul>
|
||||||
|
*
|
||||||
|
* @author Dave Syer
|
||||||
|
*/
|
||||||
|
public class DropwizardMetricWriter implements MetricWriter {
|
||||||
|
|
||||||
|
private final MetricRegistry registry;
|
||||||
|
|
||||||
|
private final ConcurrentMap<String, Object> gaugeLocks = new ConcurrentHashMap<String, Object>();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new {@link DropwizardMetricWriter} instance.
|
||||||
|
* @param registry the underlying metric registry
|
||||||
|
*/
|
||||||
|
public DropwizardMetricWriter(MetricRegistry registry) {
|
||||||
|
this.registry = registry;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void increment(Delta<?> delta) {
|
||||||
|
String name = delta.getName();
|
||||||
|
long value = delta.getValue().longValue();
|
||||||
|
if (name.startsWith("meter")) {
|
||||||
|
Meter meter = this.registry.meter(name);
|
||||||
|
meter.mark(value);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
Counter counter = this.registry.counter(name);
|
||||||
|
counter.inc(value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void set(Metric<?> value) {
|
||||||
|
String name = value.getName();
|
||||||
|
if (name.startsWith("histogram")) {
|
||||||
|
long longValue = value.getValue().longValue();
|
||||||
|
Histogram metric = this.registry.histogram(name);
|
||||||
|
metric.update(longValue);
|
||||||
|
}
|
||||||
|
else if (name.startsWith("timer")) {
|
||||||
|
long longValue = value.getValue().longValue();
|
||||||
|
Timer metric = this.registry.timer(name);
|
||||||
|
metric.update(longValue, TimeUnit.MILLISECONDS);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
final double gauge = value.getValue().doubleValue();
|
||||||
|
// Ensure we synchronize to avoid another thread pre-empting this thread after
|
||||||
|
// remove causing an error in CodaHale metrics
|
||||||
|
// NOTE: CodaHale provides no way to do this atomically
|
||||||
|
synchronized (getGuageLock(name)) {
|
||||||
|
this.registry.remove(name);
|
||||||
|
this.registry.register(name, new SimpleGauge(gauge));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private Object getGuageLock(String name) {
|
||||||
|
Object lock = this.gaugeLocks.get(name);
|
||||||
|
if (lock == null) {
|
||||||
|
Object newLock = new Object();
|
||||||
|
lock = this.gaugeLocks.putIfAbsent(name, newLock);
|
||||||
|
lock = (lock == null ? newLock : lock);
|
||||||
|
}
|
||||||
|
return lock;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void reset(String metricName) {
|
||||||
|
this.registry.remove(metricName);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Simple {@link Gauge} implementation to {@literal double} value.
|
||||||
|
*/
|
||||||
|
private static class SimpleGauge implements Gauge<Double> {
|
||||||
|
|
||||||
|
private final double value;
|
||||||
|
|
||||||
|
private SimpleGauge(double value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Double getValue() {
|
||||||
|
return this.value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
@ -29,12 +29,14 @@ import static org.junit.Assert.assertEquals;
|
||||||
import static org.junit.Assert.assertFalse;
|
import static org.junit.Assert.assertFalse;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* Tests for {@link DropwizardMetricWriter}.
|
||||||
|
*
|
||||||
* @author Dave Syer
|
* @author Dave Syer
|
||||||
*/
|
*/
|
||||||
public class CodahaleMetricWriterTests {
|
public class DropwizardMetricWriterTests {
|
||||||
|
|
||||||
private final MetricRegistry registry = new MetricRegistry();
|
private final MetricRegistry registry = new MetricRegistry();
|
||||||
private final CodahaleMetricWriter writer = new CodahaleMetricWriter(this.registry);
|
private final DropwizardMetricWriter writer = new DropwizardMetricWriter(this.registry);
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void incrementCounter() {
|
public void incrementCounter() {
|
||||||
|
|
@ -110,9 +112,9 @@ public class CodahaleMetricWriterTests {
|
||||||
public static class WriterThread extends Thread {
|
public static class WriterThread extends Thread {
|
||||||
private int index;
|
private int index;
|
||||||
private boolean failed;
|
private boolean failed;
|
||||||
private CodahaleMetricWriter writer;
|
private DropwizardMetricWriter writer;
|
||||||
|
|
||||||
public WriterThread(ThreadGroup group, int index, CodahaleMetricWriter writer) {
|
public WriterThread(ThreadGroup group, int index, DropwizardMetricWriter writer) {
|
||||||
super(group, "Writer-" + index);
|
super(group, "Writer-" + index);
|
||||||
|
|
||||||
this.index = index;
|
this.index = index;
|
||||||
Loading…
Reference in New Issue