Chia-Ping Tsai created KAFKA-17153:
--------------------------------------
Summary: KafkaMetricsGroup#newGauge should accept functional
interface instead of `com.yammer.metrics.core.Gague`
Key: KAFKA-17153
URL: https://issues.apache.org/jira/browse/KAFKA-17153
Project: Kafka
Issue Type: Improvement
Reporter: Chia-Ping Tsai
Assignee: Chia-Ping Tsai
This is a kind of syntactic sugar. Java disallow lambdas to implement abstract
classes, and hence there are many ugly impl of Gague in code base [0][1][2][3].
Those bad looking code will spring up as we migrate more and more scala code to
java.
Hence, we should offer a variety to accept functional interface for java code.
For example:
{code:java}
public final <T> Gauge<T> newGauge(String name, Supplier<T> metric) {
return newGauge(name, new Gauge<T>() {
@Override
public T value() {
return metric.get();
}
}, Collections.emptyMap());
}
{code}
[0]
https://github.com/apache/kafka/blob/b015a83f6d286965af999c39c0902584fb6fb9de/server/src/main/java/org/apache/kafka/server/AssignmentsManager.java#L109
[1]
https://github.com/apache/kafka/blob/b015a83f6d286965af999c39c0902584fb6fb9de/metadata/src/main/java/org/apache/kafka/image/loader/metrics/MetadataLoaderMetrics.java#L73
[2]
https://github.com/apache/kafka/blob/b015a83f6d286965af999c39c0902584fb6fb9de/metadata/src/main/java/org/apache/kafka/controller/metrics/ControllerMetadataMetrics.java#L106
[3]
https://github.com/apache/kafka/blob/b015a83f6d286965af999c39c0902584fb6fb9de/storage/src/main/java/org/apache/kafka/storage/internals/log/RemoteStorageThreadPool.java#L54
--
This message was sent by Atlassian Jira
(v8.20.10#820010)