Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
24 changes: 15 additions & 9 deletions pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,8 @@

<module>ratis-examples</module>
<module>ratis-replicated-map</module>
<module>ratis-metrics</module>
<module>ratis-metrics-api</module>
<module>ratis-metrics-default</module>
<module>ratis-tools</module>
<module>ratis-shell</module>
<module>ratis-assembly</module>
Expand Down Expand Up @@ -271,16 +272,21 @@
<version>${project.version}</version>
</dependency>
<dependency>
<artifactId>ratis-metrics</artifactId>
<groupId>org.apache.ratis</groupId>
<version>${project.version}</version>
<artifactId>ratis-metrics-api</artifactId>
<groupId>org.apache.ratis</groupId>
<version>${project.version}</version>
</dependency>
<dependency>
<artifactId>ratis-metrics-default</artifactId>
<groupId>org.apache.ratis</groupId>
<version>${project.version}</version>
</dependency>
<dependency>
<artifactId>ratis-metrics</artifactId>
<groupId>org.apache.ratis</groupId>
<version>${project.version}</version>
<type>test-jar</type>
<scope>test</scope>
<artifactId>ratis-metrics-default</artifactId>
<groupId>org.apache.ratis</groupId>
<version>${project.version}</version>
<type>test-jar</type>
<scope>test</scope>
</dependency>
<dependency>
<artifactId>ratis-tools</artifactId>
Expand Down
6 changes: 5 additions & 1 deletion ratis-assembly/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -291,7 +291,11 @@

<dependency>
<groupId>org.apache.ratis</groupId>
<artifactId>ratis-metrics</artifactId>
<artifactId>ratis-metrics-api</artifactId>
</dependency>
<dependency>
<groupId>org.apache.ratis</groupId>
<artifactId>ratis-metrics-default</artifactId>
</dependency>
<dependency>
<groupId>org.apache.ratis</groupId>
Expand Down
3 changes: 2 additions & 1 deletion ratis-assembly/src/main/assembly/bin.xml
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,8 @@
<include>org.apache.ratis:ratis-server-api</include>
<include>org.apache.ratis:ratis-server</include>
<include>org.apache.ratis:ratis-test</include>
<include>org.apache.ratis:ratis-metrics</include>
<include>org.apache.ratis:ratis-metrics-api</include>
<include>org.apache.ratis:ratis-metrics-default</include>
<include>org.apache.ratis:ratis-tools</include>
<include>org.apache.ratis:ratis-resource-bundle</include>
</includes>
Expand Down
3 changes: 2 additions & 1 deletion ratis-assembly/src/main/assembly/src.xml
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,8 @@
<include>org.apache.ratis:ratis-server</include>
<include>org.apache.ratis:ratis-shell</include>
<include>org.apache.ratis:ratis-test</include>
<include>org.apache.ratis:ratis-metrics</include>
<include>org.apache.ratis:ratis-metrics-api</include>
<include>org.apache.ratis:ratis-metrics-default</include>
<include>org.apache.ratis:ratis-tools</include>
<include>org.apache.ratis:ratis-resource-bundle</include>
</includes>
Expand Down
5 changes: 5 additions & 0 deletions ratis-examples/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,11 @@
<type>test-jar</type>
</dependency>

<dependency>
<artifactId>ratis-metrics-default</artifactId>
<groupId>org.apache.ratis</groupId>
</dependency>

<dependency>
<artifactId>ratis-grpc</artifactId>
<groupId>org.apache.ratis</groupId>
Expand Down
38 changes: 38 additions & 0 deletions ratis-metrics-api/pom.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
<?xml version="1.0" encoding="UTF-8"?>
<!--
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. See accompanying LICENSE file.
-->
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<artifactId>ratis</artifactId>
<groupId>org.apache.ratis</groupId>
<version>3.0.0-SNAPSHOT</version>
</parent>

<artifactId>ratis-metrics-api</artifactId>
<name>Apache Ratis Metrics API</name>

<dependencies>
<dependency>
<artifactId>ratis-common</artifactId>
<groupId>org.apache.ratis</groupId>
</dependency>

<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</dependency>
</dependencies>
</project>
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
/**
*
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
Expand All @@ -16,8 +15,6 @@
* See the License for the specific language governing permissions and
* limitations under the License.
*/


package org.apache.ratis.metrics;

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,23 +18,25 @@

package org.apache.ratis.metrics;

import org.apache.ratis.thirdparty.com.codahale.metrics.MetricRegistry;
import org.apache.ratis.util.JavaUtils;
import org.apache.ratis.util.MemoizedSupplier;

import java.util.Objects;
import java.util.function.Supplier;

/**
*
* This class holds the name and description and JMX related context names for such group of
* metrics.
* This class holds the name, description and JMX related context names for such group of metrics.
* <p>
* This class is immutable.
*/
public class MetricRegistryInfo {

private final String prefix;
private final String metricsDescription;
private final String metricsComponentName;
private final String fullName;
private final String applicationName;

private final Supplier<Integer> hash = MemoizedSupplier.valueOf(this::computeHash);

/**
* @param prefix className or component name this metric registry collects metric for
* @param applicationName application Name needs to be in small case as it is used for hadoop2metrics
Expand All @@ -48,7 +50,6 @@ public MetricRegistryInfo(String prefix, String applicationName, String metricsC
this.applicationName = applicationName;
this.metricsComponentName = metricsComponentName;
this.metricsDescription = metricsDescription;
this.fullName = MetricRegistry.name(applicationName, metricsComponentName, prefix);
}

public String getApplicationName() {
Expand Down Expand Up @@ -79,21 +80,33 @@ public String getPrefix() {

@Override
public boolean equals(Object obj) {
if (obj instanceof MetricRegistryInfo) {
return this.hashCode() == obj.hashCode();
} else {
if (this == obj) {
return true;
} else if (!(obj instanceof MetricRegistryInfo)) {
return false;
}
final MetricRegistryInfo that = (MetricRegistryInfo) obj;
return Objects.equals(prefix, that.prefix)
&& Objects.equals(metricsDescription, that.metricsDescription)
&& Objects.equals(metricsComponentName, that.metricsComponentName)
&& Objects.equals(applicationName, that.applicationName);
}

@Override
public int hashCode() {
return Objects.hash(prefix, metricsDescription, metricsComponentName);
return hash.get();
}

public String getName() {
return fullName;
private Integer computeHash() {
return Objects.hash(prefix, metricsDescription, metricsComponentName);
}


@Override
public String toString() {
return JavaUtils.getClassSimpleName(getClass())
+ ": applicationName=" + getApplicationName()
+ ", metricsComponentName=" + getMetricsComponentName()
+ ", prefix=" + getPrefix()
+ ", metricsDescription=" + getMetricsDescription();
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -59,9 +59,7 @@ protected static <T extends Enum<T>> Map<T, Timekeeper> newTimerMap(
protected static RatisMetricRegistry create(MetricRegistryInfo info) {
Optional<RatisMetricRegistry> metricRegistry = MetricRegistries.global().get(info);
return metricRegistry.orElseGet(() -> {
if (LOG.isDebugEnabled()) {
LOG.debug("Creating Metrics Registry : {}", info.getName());
}
LOG.debug("Creating {}", info);
return MetricRegistries.global().create(info);
});
}
Expand All @@ -74,9 +72,7 @@ protected RatisMetrics(RatisMetricRegistry registry) {

public void unregister() {
MetricRegistryInfo info = registry.getMetricRegistryInfo();
if (LOG.isDebugEnabled()) {
LOG.debug("Unregistering Metrics Registry : {}", info.getName());
}
LOG.debug("Unregistering {}", info);
Optional<RatisMetricRegistry> metricRegistry = MetricRegistries.global().get(info);
if (metricRegistry.isPresent()) {
MetricRegistries.global().remove(info);
Expand Down
8 changes: 6 additions & 2 deletions ratis-metrics/pom.xml → ratis-metrics-default/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -21,10 +21,14 @@
<version>3.0.0-SNAPSHOT</version>
</parent>

<artifactId>ratis-metrics</artifactId>
<name>Apache Ratis Metrics</name>
<artifactId>ratis-metrics-default</artifactId>
<name>Apache Ratis Metrics Default Implementation</name>

<dependencies>
<dependency>
<artifactId>ratis-metrics-api</artifactId>
<groupId>org.apache.ratis</groupId>
</dependency>
<dependency>
<artifactId>ratis-proto</artifactId>
<groupId>org.apache.ratis</groupId>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@
import org.apache.ratis.thirdparty.com.google.common.annotations.VisibleForTesting;

import java.util.Map;
import java.util.Objects;
import java.util.SortedMap;
import java.util.function.Supplier;

Expand All @@ -49,13 +50,14 @@ static RatisMetricRegistryImpl cast(RatisMetricRegistry registry) {
private final MetricRegistry metricRegistry = new MetricRegistry();

private final MetricRegistryInfo info;
private final String namePrefix;

private JmxReporter jmxReporter;
private ConsoleReporter consoleReporter;

public RatisMetricRegistryImpl(MetricRegistryInfo info) {
super();
this.info = info;
this.info = Objects.requireNonNull(info, "info == null");
this.namePrefix = MetricRegistry.name(info.getApplicationName(), info.getMetricsComponentName(), info.getPrefix());
}

@Override
Expand Down Expand Up @@ -111,7 +113,7 @@ public Metric get(String shortName) {
}

private String getMetricName(String shortName) {
return MetricRegistry.name(info.getName(), shortName);
return MetricRegistry.name(namePrefix, shortName);
}

private <T extends Metric> T register(String name, T metric) throws IllegalArgumentException {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/**
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
Expand Down
45 changes: 0 additions & 45 deletions ratis-metrics/src/test/resources/hadoop-metrics2.properties

This file was deleted.

6 changes: 3 additions & 3 deletions ratis-server/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -82,15 +82,15 @@
</dependency>
<dependency>
<groupId>org.apache.ratis</groupId>
<artifactId>ratis-metrics</artifactId>
<artifactId>ratis-metrics-api</artifactId>
</dependency>
<dependency>
<groupId>org.apache.ratis</groupId>
<artifactId>ratis-metrics</artifactId>
<type>test-jar</type>
<artifactId>ratis-metrics-default</artifactId>
<scope>test</scope>
</dependency>


<dependency>
<groupId>com.github.spotbugs</groupId>
<artifactId>spotbugs-annotations</artifactId>
Expand Down
6 changes: 6 additions & 0 deletions ratis-test/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,12 @@
<type>test-jar</type>
</dependency>

<dependency>
<artifactId>ratis-metrics-default</artifactId>
<groupId>org.apache.ratis</groupId>
<scope>test</scope>
</dependency>

<dependency>
<artifactId>ratis-netty</artifactId>
<groupId>org.apache.ratis</groupId>
Expand Down