Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in / Register
Toggle navigation
S
spring-boot
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
DEMO
spring-boot
Commits
888a81be
Commit
888a81be
authored
Apr 06, 2020
by
Stephane Nicoll
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Migrate Kafka metrics to KafkaClientMetrics
Closes gh-20838
parent
333ac279
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
30 additions
and
29 deletions
+30
-29
build.gradle
...t-project/spring-boot-actuator-autoconfigure/build.gradle
+1
-0
KafkaMetricsAutoConfiguration.java
.../autoconfigure/metrics/KafkaMetricsAutoConfiguration.java
+11
-11
KafkaMetricsAutoConfigurationTests.java
...configure/metrics/KafkaMetricsAutoConfigurationTests.java
+17
-17
production-ready-features.adoc
...oot-docs/src/docs/asciidoc/production-ready-features.adoc
+1
-1
No files found.
spring-boot-project/spring-boot-actuator-autoconfigure/build.gradle
View file @
888a81be
...
@@ -101,6 +101,7 @@ dependencies {
...
@@ -101,6 +101,7 @@ dependencies {
optional
(
"org.springframework.data:spring-data-redis"
)
optional
(
"org.springframework.data:spring-data-redis"
)
optional
(
"org.springframework.data:spring-data-solr"
)
optional
(
"org.springframework.data:spring-data-solr"
)
optional
(
"org.springframework.integration:spring-integration-core"
)
optional
(
"org.springframework.integration:spring-integration-core"
)
optional
(
"org.springframework.kafka:spring-kafka"
)
optional
(
"org.springframework.security:spring-security-config"
)
optional
(
"org.springframework.security:spring-security-config"
)
optional
(
"org.springframework.security:spring-security-web"
)
optional
(
"org.springframework.security:spring-security-web"
)
optional
(
"org.springframework.session:spring-session-core"
)
optional
(
"org.springframework.session:spring-session-core"
)
...
...
spring-boot-project/spring-boot-actuator-autoconfigure/src/main/java/org/springframework/boot/actuate/autoconfigure/metrics/KafkaMetricsAutoConfiguration.java
View file @
888a81be
/*
/*
* Copyright 2012-20
19
the original author or authors.
* Copyright 2012-20
20
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.
...
@@ -18,37 +18,37 @@ package org.springframework.boot.actuate.autoconfigure.metrics;
...
@@ -18,37 +18,37 @@ package org.springframework.boot.actuate.autoconfigure.metrics;
import
java.util.Collections
;
import
java.util.Collections
;
import
javax.management.MBeanServer
;
import
io.micrometer.core.instrument.MeterRegistry
;
import
io.micrometer.core.instrument.MeterRegistry
;
import
io.micrometer.core.instrument.binder.kafka.KafkaConsumerMetrics
;
import
io.micrometer.core.instrument.binder.kafka.KafkaClientMetrics
;
import
org.apache.kafka.clients.consumer.KafkaConsumer
;
import
org.springframework.boot.autoconfigure.AutoConfigureAfter
;
import
org.springframework.boot.autoconfigure.AutoConfigureAfter
;
import
org.springframework.boot.autoconfigure.condition.ConditionalOnBean
;
import
org.springframework.boot.autoconfigure.condition.ConditionalOnBean
;
import
org.springframework.boot.autoconfigure.condition.ConditionalOnClass
;
import
org.springframework.boot.autoconfigure.condition.ConditionalOnClass
;
import
org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean
;
import
org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean
;
import
org.springframework.boot.autoconfigure.jmx.JmxAutoConfiguration
;
import
org.springframework.boot.autoconfigure.condition.ConditionalOnSingleCandidate
;
import
org.springframework.boot.autoconfigure.kafka.KafkaAutoConfiguration
;
import
org.springframework.context.annotation.Bean
;
import
org.springframework.context.annotation.Bean
;
import
org.springframework.context.annotation.Configuration
;
import
org.springframework.context.annotation.Configuration
;
import
org.springframework.kafka.core.ProducerFactory
;
/**
/**
* Auto-configuration for Kafka metrics.
* Auto-configuration for Kafka metrics.
*
*
* @author Andy Wilkinson
* @author Andy Wilkinson
* @author Stephane Nicoll
* @since 2.1.0
* @since 2.1.0
*/
*/
@Configuration
(
proxyBeanMethods
=
false
)
@Configuration
(
proxyBeanMethods
=
false
)
@AutoConfigureAfter
({
MetricsAutoConfiguration
.
class
,
Jmx
AutoConfiguration
.
class
})
@AutoConfigureAfter
({
MetricsAutoConfiguration
.
class
,
Kafka
AutoConfiguration
.
class
})
@ConditionalOnClass
({
KafkaC
onsumerMetrics
.
class
,
KafkaConsumer
.
class
})
@ConditionalOnClass
({
KafkaC
lientMetrics
.
class
,
ProducerFactory
.
class
})
@ConditionalOnBean
(
MeterRegistry
.
class
)
@ConditionalOnBean
(
MeterRegistry
.
class
)
public
class
KafkaMetricsAutoConfiguration
{
public
class
KafkaMetricsAutoConfiguration
{
@Bean
@Bean
@ConditionalOnMissingBean
@ConditionalOnMissingBean
@ConditionalOn
Bean
(
MBeanServer
.
class
)
@ConditionalOn
SingleCandidate
(
ProducerFactory
.
class
)
public
KafkaC
onsumerMetrics
kafkaConsumerMetrics
(
MBeanServer
mbeanServer
)
{
public
KafkaC
lientMetrics
kafkaClientMetrics
(
ProducerFactory
<?,
?>
producerFactory
)
{
return
new
KafkaC
onsumerMetrics
(
mbeanServer
,
Collections
.
emptyList
());
return
new
KafkaC
lientMetrics
(
producerFactory
.
createProducer
()
,
Collections
.
emptyList
());
}
}
}
}
spring-boot-project/spring-boot-actuator-autoconfigure/src/test/java/org/springframework/boot/actuate/autoconfigure/metrics/KafkaMetricsAutoConfigurationTests.java
View file @
888a81be
/*
/*
* Copyright 2012-20
19
the original author or authors.
* Copyright 2012-20
20
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,54 +16,54 @@
...
@@ -16,54 +16,54 @@
package
org
.
springframework
.
boot
.
actuate
.
autoconfigure
.
metrics
;
package
org
.
springframework
.
boot
.
actuate
.
autoconfigure
.
metrics
;
import
io.micrometer.core.instrument.binder.kafka.KafkaC
onsumer
Metrics
;
import
io.micrometer.core.instrument.binder.kafka.KafkaC
lient
Metrics
;
import
org.junit.jupiter.api.Test
;
import
org.junit.jupiter.api.Test
;
import
org.springframework.boot.actuate.autoconfigure.metrics.test.MetricsRun
;
import
org.springframework.boot.actuate.autoconfigure.metrics.test.MetricsRun
;
import
org.springframework.boot.autoconfigure.AutoConfigurations
;
import
org.springframework.boot.autoconfigure.AutoConfigurations
;
import
org.springframework.boot.autoconfigure.
jmx.Jmx
AutoConfiguration
;
import
org.springframework.boot.autoconfigure.
kafka.Kafka
AutoConfiguration
;
import
org.springframework.boot.test.context.runner.ApplicationContextRunner
;
import
org.springframework.boot.test.context.runner.ApplicationContextRunner
;
import
org.springframework.context.annotation.Bean
;
import
org.springframework.context.annotation.Bean
;
import
org.springframework.context.annotation.Configuration
;
import
org.springframework.context.annotation.Configuration
;
import
static
org
.
assertj
.
core
.
api
.
Assertions
.
assertThat
;
import
static
org
.
assertj
.
core
.
api
.
Assertions
.
assertThat
;
import
static
org
.
mockito
.
Mockito
.
mock
;
/**
/**
* Tests for {@link KafkaMetricsAutoConfiguration}.
* Tests for {@link KafkaMetricsAutoConfiguration}.
*
*
* @author Andy Wilkinson
* @author Andy Wilkinson
* @author Stephane Nicoll
*/
*/
class
KafkaMetricsAutoConfigurationTests
{
class
KafkaMetricsAutoConfigurationTests
{
private
final
ApplicationContextRunner
contextRunner
=
new
ApplicationContextRunner
().
with
(
MetricsRun
.
simple
())
private
final
ApplicationContextRunner
contextRunner
=
new
ApplicationContextRunner
().
with
(
MetricsRun
.
simple
())
.
withPropertyValues
(
"spring.jmx.enabled=true"
)
.
withConfiguration
(
AutoConfigurations
.
of
(
KafkaMetricsAutoConfiguration
.
class
));
.
withConfiguration
(
AutoConfigurations
.
of
(
KafkaMetricsAutoConfiguration
.
class
));
@Test
@Test
void
whenThereIsNo
MBeanServer
AutoConfigurationBacksOff
()
{
void
whenThereIsNo
ProducerFactory
AutoConfigurationBacksOff
()
{
this
.
contextRunner
.
run
((
context
)
->
assertThat
(
context
).
doesNotHaveBean
(
KafkaC
onsumer
Metrics
.
class
));
this
.
contextRunner
.
run
((
context
)
->
assertThat
(
context
).
doesNotHaveBean
(
KafkaC
lient
Metrics
.
class
));
}
}
@Test
@Test
void
whenThereIsAn
MBeanServerKafkaConsumer
MetricsIsConfigured
()
{
void
whenThereIsAn
AProducerFactoryKafkaClient
MetricsIsConfigured
()
{
this
.
contextRunner
.
withConfiguration
(
AutoConfigurations
.
of
(
Jmx
AutoConfiguration
.
class
))
this
.
contextRunner
.
withConfiguration
(
AutoConfigurations
.
of
(
Kafka
AutoConfiguration
.
class
))
.
run
((
context
)
->
assertThat
(
context
).
hasSingleBean
(
KafkaC
onsumer
Metrics
.
class
));
.
run
((
context
)
->
assertThat
(
context
).
hasSingleBean
(
KafkaC
lient
Metrics
.
class
));
}
}
@Test
@Test
void
allowsCustomKafkaConsumerMetricsToBeUsed
()
{
void
allowsCustomKafkaClientMetricsToBeUsed
()
{
this
.
contextRunner
.
withConfiguration
(
AutoConfigurations
.
of
(
JmxAutoConfiguration
.
class
))
this
.
contextRunner
.
withConfiguration
(
AutoConfigurations
.
of
(
KafkaAutoConfiguration
.
class
))
.
withUserConfiguration
(
CustomKafkaConsumerMetricsConfiguration
.
class
)
.
withUserConfiguration
(
CustomKafkaClientMetricsConfiguration
.
class
).
run
((
context
)
->
assertThat
(
context
)
.
run
((
context
)
->
assertThat
(
context
).
hasSingleBean
(
KafkaConsumerMetrics
.
class
)
.
hasSingleBean
(
KafkaClientMetrics
.
class
).
hasBean
(
"customKafkaClientMetrics"
));
.
hasBean
(
"customKafkaConsumerMetrics"
));
}
}
@Configuration
(
proxyBeanMethods
=
false
)
@Configuration
(
proxyBeanMethods
=
false
)
static
class
CustomKafkaC
onsumer
MetricsConfiguration
{
static
class
CustomKafkaC
lient
MetricsConfiguration
{
@Bean
@Bean
KafkaC
onsumerMetrics
customKafkaConsumer
Metrics
()
{
KafkaC
lientMetrics
customKafkaClient
Metrics
()
{
return
new
KafkaConsumerMetrics
(
);
return
mock
(
KafkaClientMetrics
.
class
);
}
}
}
}
...
...
spring-boot-project/spring-boot-docs/src/docs/asciidoc/production-ready-features.adoc
View file @
888a81be
...
@@ -1791,7 +1791,7 @@ Spring Boot registers the following core metrics when applicable:
...
@@ -1791,7 +1791,7 @@ Spring Boot registers the following core metrics when applicable:
** Number of classes loaded/unloaded
** Number of classes loaded/unloaded
* CPU metrics
* CPU metrics
* File descriptor metrics
* File descriptor metrics
* Kafka consumer metrics
(<<production-ready-jmx,JMX support>> should be enabled)
* Kafka consumer metrics
* Log4j2 metrics: record the number of events logged to Log4j2 at each level
* Log4j2 metrics: record the number of events logged to Log4j2 at each level
* Logback metrics: record the number of events logged to Logback at each level
* Logback metrics: record the number of events logged to Logback at each level
* Uptime metrics: report a gauge for uptime and a fixed gauge representing the application's absolute start time
* Uptime metrics: report a gauge for uptime and a fixed gauge representing the application's absolute start time
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment