/* * Copyright 2016 Composable Systems Limited * * 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 systems.composable.dropwizard.cassandra; import com.codahale.metrics.Metric; import com.codahale.metrics.MetricSet; import com.datastax.driver.core.Cluster; import com.google.common.collect.ImmutableMap; import java.util.Map; import static com.codahale.metrics.MetricRegistry.name; /** * Exposes the metrics provided by the provided Cluster, embedding the cluster name in the metric name. * <p/> * Metrics are named based on the DataStax {@link Cluster} class, the cluster name, and the original name of the metric * exposed by the driver. With the current version of the driver - v2.0.2 at the time of writing - this includes: * * <b>Counters:</b> * <ul> * <li>com.datastax.core.Cluster.clusterName.connection-errors</li> * <li>com.datastax.core.Cluster.clusterName.write-timeouts</li> * <li>com.datastax.core.Cluster.clusterName.read-timeouts</li> * <li>com.datastax.core.Cluster.clusterName.unavailables</li> * <li>com.datastax.core.Cluster.clusterName.other-errors</li> * <li>com.datastax.core.Cluster.clusterName.retries</li> * <li>com.datastax.core.Cluster.clusterName.ignores</li> * </ul> * * <b>Gauges:</b> * <ul> * <li>com.datastax.core.Cluster.clusterName.open-connections</li> * <li>com.datastax.core.Cluster.clusterName.connected-to</li> * <li>com.datastax.core.Cluster.clusterName.known-hosts</li> * </ul> * * <b>Timers:</b> * <ul> * <li>com.datastax.core.Cluster.clusterName.requests</li> * </ul> */ public class CassandraMetricSet implements MetricSet { private Map<String, Metric> metrics; public CassandraMetricSet(Cluster cluster) { final String clusterName = cluster.getClusterName(); Map<String, Metric> driverMetrics = cluster.getMetrics().getRegistry().getMetrics(); ImmutableMap.Builder<String, Metric> builder = ImmutableMap.builder(); driverMetrics.forEach((k, v) -> builder.put(name(Cluster.class, clusterName, k), v)); metrics = builder.build(); } @Override public Map<String, Metric> getMetrics() { return metrics; } }