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
68cd27c4
Commit
68cd27c4
authored
Jun 01, 2018
by
Andy Wilkinson
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Do not require DataSourcePoolMetrics to auto-configure Hikari meters
Closes gh-13330
parent
27267a70
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
101 additions
and
43 deletions
+101
-43
DataSourcePoolMetricsAutoConfiguration.java
.../metrics/jdbc/DataSourcePoolMetricsAutoConfiguration.java
+35
-29
DataSourcePoolMetricsAutoConfigurationTests.java
...ics/jdbc/DataSourcePoolMetricsAutoConfigurationTests.java
+66
-14
No files found.
spring-boot-project/spring-boot-actuator-autoconfigure/src/main/java/org/springframework/boot/actuate/autoconfigure/metrics/jdbc/DataSourcePoolMetricsAutoConfiguration.java
View file @
68cd27c4
...
@@ -50,17 +50,20 @@ import org.springframework.util.StringUtils;
...
@@ -50,17 +50,20 @@ import org.springframework.util.StringUtils;
@Configuration
@Configuration
@AutoConfigureAfter
({
MetricsAutoConfiguration
.
class
,
DataSourceAutoConfiguration
.
class
,
@AutoConfigureAfter
({
MetricsAutoConfiguration
.
class
,
DataSourceAutoConfiguration
.
class
,
SimpleMetricsExportAutoConfiguration
.
class
})
SimpleMetricsExportAutoConfiguration
.
class
})
@ConditionalOnBean
({
DataSource
.
class
,
DataSourcePoolMetadataProvider
.
class
,
@ConditionalOnBean
({
DataSource
.
class
,
MeterRegistry
.
class
})
MeterRegistry
.
class
})
public
class
DataSourcePoolMetricsAutoConfiguration
{
public
class
DataSourcePoolMetricsAutoConfiguration
{
@Configuration
@ConditionalOnBean
(
DataSourcePoolMetadataProvider
.
class
)
static
class
DataSourcePoolMetadataMetricsConfiguration
{
private
static
final
String
DATASOURCE_SUFFIX
=
"dataSource"
;
private
static
final
String
DATASOURCE_SUFFIX
=
"dataSource"
;
private
final
MeterRegistry
registry
;
private
final
MeterRegistry
registry
;
private
final
Collection
<
DataSourcePoolMetadataProvider
>
metadataProviders
;
private
final
Collection
<
DataSourcePoolMetadataProvider
>
metadataProviders
;
public
DataSourcePoolMetricsAuto
Configuration
(
MeterRegistry
registry
,
DataSourcePoolMetadataMetrics
Configuration
(
MeterRegistry
registry
,
Collection
<
DataSourcePoolMetadataProvider
>
metadataProviders
)
{
Collection
<
DataSourcePoolMetadataProvider
>
metadataProviders
)
{
this
.
registry
=
registry
;
this
.
registry
=
registry
;
this
.
metadataProviders
=
metadataProviders
;
this
.
metadataProviders
=
metadataProviders
;
...
@@ -85,11 +88,14 @@ public class DataSourcePoolMetricsAutoConfiguration {
...
@@ -85,11 +88,14 @@ public class DataSourcePoolMetricsAutoConfiguration {
private
String
getDataSourceName
(
String
beanName
)
{
private
String
getDataSourceName
(
String
beanName
)
{
if
(
beanName
.
length
()
>
DATASOURCE_SUFFIX
.
length
()
if
(
beanName
.
length
()
>
DATASOURCE_SUFFIX
.
length
()
&&
StringUtils
.
endsWithIgnoreCase
(
beanName
,
DATASOURCE_SUFFIX
))
{
&&
StringUtils
.
endsWithIgnoreCase
(
beanName
,
DATASOURCE_SUFFIX
))
{
return
beanName
.
substring
(
0
,
beanName
.
length
()
-
DATASOURCE_SUFFIX
.
length
());
return
beanName
.
substring
(
0
,
beanName
.
length
()
-
DATASOURCE_SUFFIX
.
length
());
}
}
return
beanName
;
return
beanName
;
}
}
}
@Configuration
@Configuration
@ConditionalOnClass
(
HikariDataSource
.
class
)
@ConditionalOnClass
(
HikariDataSource
.
class
)
static
class
HikariDataSourceMetricsConfiguration
{
static
class
HikariDataSourceMetricsConfiguration
{
...
...
spring-boot-project/spring-boot-actuator-autoconfigure/src/test/java/org/springframework/boot/actuate/autoconfigure/metrics/jdbc/DataSourcePoolMetricsAutoConfigurationTests.java
View file @
68cd27c4
...
@@ -33,6 +33,7 @@ import org.springframework.boot.actuate.autoconfigure.metrics.test.MetricsRun;
...
@@ -33,6 +33,7 @@ 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.jdbc.DataSourceAutoConfiguration
;
import
org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration
;
import
org.springframework.boot.jdbc.DataSourceBuilder
;
import
org.springframework.boot.jdbc.DataSourceBuilder
;
import
org.springframework.boot.jdbc.metadata.DataSourcePoolMetadataProvider
;
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
;
...
@@ -53,22 +54,29 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
...
@@ -53,22 +54,29 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
private
ApplicationContextRunner
contextRunner
=
new
ApplicationContextRunner
()
private
ApplicationContextRunner
contextRunner
=
new
ApplicationContextRunner
()
.
withPropertyValues
(
"spring.datasource.generate-unique-name=true"
)
.
withPropertyValues
(
"spring.datasource.generate-unique-name=true"
)
.
with
(
MetricsRun
.
simple
())
.
with
(
MetricsRun
.
simple
())
.
withConfiguration
(
AutoConfigurations
.
of
(
DataSourceAutoConfiguration
.
class
,
.
withConfiguration
(
DataSourcePoolMetricsAutoConfiguration
.
class
))
AutoConfigurations
.
of
(
DataSourcePoolMetricsAutoConfiguration
.
class
))
.
withUserConfiguration
(
BaseConfiguration
.
class
);
.
withUserConfiguration
(
BaseConfiguration
.
class
);
@Test
@Test
public
void
autoConfiguredDataSourceIsInstrumented
()
{
public
void
autoConfiguredDataSourceIsInstrumented
()
{
this
.
contextRunner
.
run
((
context
)
->
{
this
.
contextRunner
.
withConfiguration
(
AutoConfigurations
.
of
(
DataSourceAutoConfiguration
.
class
))
.
run
((
context
)
->
{
context
.
getBean
(
DataSource
.
class
).
getConnection
().
getMetaData
();
context
.
getBean
(
DataSource
.
class
).
getConnection
().
getMetaData
();
MeterRegistry
registry
=
context
.
getBean
(
MeterRegistry
.
class
);
MeterRegistry
registry
=
context
.
getBean
(
MeterRegistry
.
class
);
registry
.
get
(
"jdbc.connections.max"
).
tags
(
"name"
,
"dataSource"
).
meter
();
registry
.
get
(
"jdbc.connections.max"
).
tags
(
"name"
,
"dataSource"
)
.
meter
();
});
});
}
}
@Test
@Test
public
void
dataSourceInstrumentationCanBeDisabled
()
{
public
void
dataSourceInstrumentationCanBeDisabled
()
{
this
.
contextRunner
.
withPropertyValues
(
"management.metrics.enable.jdbc=false"
)
this
.
contextRunner
.
withConfiguration
(
AutoConfigurations
.
of
(
DataSourceAutoConfiguration
.
class
))
.
withPropertyValues
(
"management.metrics.enable.jdbc=false"
)
.
run
((
context
)
->
{
.
run
((
context
)
->
{
context
.
getBean
(
DataSource
.
class
).
getConnection
().
getMetaData
();
context
.
getBean
(
DataSource
.
class
).
getConnection
().
getMetaData
();
MeterRegistry
registry
=
context
.
getBean
(
MeterRegistry
.
class
);
MeterRegistry
registry
=
context
.
getBean
(
MeterRegistry
.
class
);
...
@@ -79,7 +87,10 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
...
@@ -79,7 +87,10 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
@Test
@Test
public
void
allDataSourcesCanBeInstrumented
()
{
public
void
allDataSourcesCanBeInstrumented
()
{
this
.
contextRunner
.
withUserConfiguration
(
TwoDataSourcesConfiguration
.
class
)
this
.
contextRunner
.
withConfiguration
(
AutoConfigurations
.
of
(
DataSourceAutoConfiguration
.
class
))
.
withUserConfiguration
(
TwoDataSourcesConfiguration
.
class
)
.
run
((
context
)
->
{
.
run
((
context
)
->
{
context
.
getBean
(
"firstDataSource"
,
DataSource
.
class
).
getConnection
()
context
.
getBean
(
"firstDataSource"
,
DataSource
.
class
).
getConnection
()
.
getMetaData
();
.
getMetaData
();
...
@@ -94,7 +105,10 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
...
@@ -94,7 +105,10 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
@Test
@Test
public
void
autoConfiguredHikariDataSourceIsInstrumented
()
{
public
void
autoConfiguredHikariDataSourceIsInstrumented
()
{
this
.
contextRunner
.
run
((
context
)
->
{
this
.
contextRunner
.
withConfiguration
(
AutoConfigurations
.
of
(
DataSourceAutoConfiguration
.
class
))
.
run
((
context
)
->
{
context
.
getBean
(
DataSource
.
class
).
getConnection
();
context
.
getBean
(
DataSource
.
class
).
getConnection
();
MeterRegistry
registry
=
context
.
getBean
(
MeterRegistry
.
class
);
MeterRegistry
registry
=
context
.
getBean
(
MeterRegistry
.
class
);
registry
.
get
(
"hikaricp.connections"
).
meter
();
registry
.
get
(
"hikaricp.connections"
).
meter
();
...
@@ -106,6 +120,8 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
...
@@ -106,6 +120,8 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
this
.
contextRunner
this
.
contextRunner
.
withPropertyValues
(
.
withPropertyValues
(
"spring.datasource.schema:db/create-custom-schema.sql"
)
"spring.datasource.schema:db/create-custom-schema.sql"
)
.
withConfiguration
(
AutoConfigurations
.
of
(
DataSourceAutoConfiguration
.
class
))
.
run
((
context
)
->
{
.
run
((
context
)
->
{
context
.
getBean
(
DataSource
.
class
).
getConnection
();
context
.
getBean
(
DataSource
.
class
).
getConnection
();
MeterRegistry
registry
=
context
.
getBean
(
MeterRegistry
.
class
);
MeterRegistry
registry
=
context
.
getBean
(
MeterRegistry
.
class
);
...
@@ -116,6 +132,8 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
...
@@ -116,6 +132,8 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
@Test
@Test
public
void
hikariCanBeInstrumentedAfterThePoolHasBeenSealed
()
{
public
void
hikariCanBeInstrumentedAfterThePoolHasBeenSealed
()
{
this
.
contextRunner
.
withUserConfiguration
(
HikariSealingConfiguration
.
class
)
this
.
contextRunner
.
withUserConfiguration
(
HikariSealingConfiguration
.
class
)
.
withConfiguration
(
AutoConfigurations
.
of
(
DataSourceAutoConfiguration
.
class
))
.
run
((
context
)
->
{
.
run
((
context
)
->
{
assertThat
(
context
).
hasNotFailed
();
assertThat
(
context
).
hasNotFailed
();
context
.
getBean
(
DataSource
.
class
).
getConnection
();
context
.
getBean
(
DataSource
.
class
).
getConnection
();
...
@@ -127,6 +145,8 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
...
@@ -127,6 +145,8 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
@Test
@Test
public
void
hikariDataSourceInstrumentationCanBeDisabled
()
{
public
void
hikariDataSourceInstrumentationCanBeDisabled
()
{
this
.
contextRunner
.
withPropertyValues
(
"management.metrics.enable.hikaricp=false"
)
this
.
contextRunner
.
withPropertyValues
(
"management.metrics.enable.hikaricp=false"
)
.
withConfiguration
(
AutoConfigurations
.
of
(
DataSourceAutoConfiguration
.
class
))
.
run
((
context
)
->
{
.
run
((
context
)
->
{
context
.
getBean
(
DataSource
.
class
).
getConnection
();
context
.
getBean
(
DataSource
.
class
).
getConnection
();
MeterRegistry
registry
=
context
.
getBean
(
MeterRegistry
.
class
);
MeterRegistry
registry
=
context
.
getBean
(
MeterRegistry
.
class
);
...
@@ -137,6 +157,8 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
...
@@ -137,6 +157,8 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
@Test
@Test
public
void
allHikariDataSourcesCanBeInstrumented
()
{
public
void
allHikariDataSourcesCanBeInstrumented
()
{
this
.
contextRunner
.
withUserConfiguration
(
TwoHikariDataSourcesConfiguration
.
class
)
this
.
contextRunner
.
withUserConfiguration
(
TwoHikariDataSourcesConfiguration
.
class
)
.
withConfiguration
(
AutoConfigurations
.
of
(
DataSourceAutoConfiguration
.
class
))
.
run
((
context
)
->
{
.
run
((
context
)
->
{
context
.
getBean
(
"firstDataSource"
,
DataSource
.
class
).
getConnection
();
context
.
getBean
(
"firstDataSource"
,
DataSource
.
class
).
getConnection
();
context
.
getBean
(
"secondOne"
,
DataSource
.
class
).
getConnection
();
context
.
getBean
(
"secondOne"
,
DataSource
.
class
).
getConnection
();
...
@@ -151,6 +173,8 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
...
@@ -151,6 +173,8 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
@Test
@Test
public
void
someHikariDataSourcesCanBeInstrumented
()
{
public
void
someHikariDataSourcesCanBeInstrumented
()
{
this
.
contextRunner
.
withUserConfiguration
(
MixedDataSourcesConfiguration
.
class
)
this
.
contextRunner
.
withUserConfiguration
(
MixedDataSourcesConfiguration
.
class
)
.
withConfiguration
(
AutoConfigurations
.
of
(
DataSourceAutoConfiguration
.
class
))
.
run
((
context
)
->
{
.
run
((
context
)
->
{
context
.
getBean
(
"firstDataSource"
,
DataSource
.
class
).
getConnection
();
context
.
getBean
(
"firstDataSource"
,
DataSource
.
class
).
getConnection
();
context
.
getBean
(
"secondOne"
,
DataSource
.
class
).
getConnection
();
context
.
getBean
(
"secondOne"
,
DataSource
.
class
).
getConnection
();
...
@@ -161,6 +185,20 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
...
@@ -161,6 +185,20 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
});
});
}
}
@Test
public
void
hikariDataSourceIsInstrumentedWithoutMetadataProvider
()
{
this
.
contextRunner
.
withUserConfiguration
(
OneHikariDataSourceConfiguration
.
class
)
.
run
((
context
)
->
{
assertThat
(
context
)
.
doesNotHaveBean
(
DataSourcePoolMetadataProvider
.
class
);
context
.
getBean
(
"hikariDataSource"
,
DataSource
.
class
).
getConnection
();
MeterRegistry
registry
=
context
.
getBean
(
MeterRegistry
.
class
);
assertThat
(
registry
.
get
(
"hikaricp.connections"
).
meter
().
getId
()
.
getTags
())
.
containsExactly
(
Tag
.
of
(
"pool"
,
"hikariDataSource"
));
});
}
@Configuration
@Configuration
static
class
BaseConfiguration
{
static
class
BaseConfiguration
{
...
@@ -214,6 +252,20 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
...
@@ -214,6 +252,20 @@ public class DataSourcePoolMetricsAutoConfigurationTests {
}
}
@Configuration
static
class
OneHikariDataSourceConfiguration
{
@Bean
public
DataSource
hikariDataSource
()
{
String
url
=
"jdbc:hsqldb:mem:test-"
+
UUID
.
randomUUID
();
HikariDataSource
hikariDataSource
=
DataSourceBuilder
.
create
().
url
(
url
)
.
type
(
HikariDataSource
.
class
).
build
();
hikariDataSource
.
setPoolName
(
"hikariDataSource"
);
return
hikariDataSource
;
}
}
@Configuration
@Configuration
static
class
MixedDataSourcesConfiguration
{
static
class
MixedDataSourcesConfiguration
{
...
...
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