阅读HikariCP wiki 上有关如何启用 Dropwizard 指标的说明,它说只需在or中配置一个MetricsRegistry
实例。HikariConfig
HikariDatasource
问题是,在 Spring Boot 中,所有配置都由自动配置处理,所以我根本没有手动配置 HikariCP 池。
有关如何执行此操作的任何说明?我是否必须通过定义自己的 bean 并在@Configuration
文件中设置所有设置来完全覆盖自动配置?
阅读HikariCP wiki 上有关如何启用 Dropwizard 指标的说明,它说只需在or中配置一个MetricsRegistry
实例。HikariConfig
HikariDatasource
问题是,在 Spring Boot 中,所有配置都由自动配置处理,所以我根本没有手动配置 HikariCP 池。
有关如何执行此操作的任何说明?我是否必须通过定义自己的 bean 并在@Configuration
文件中设置所有设置来完全覆盖自动配置?
或者让 Spring Boot 配置您的数据源,@Autowire 在您的 @Configuration/@SpringBootApplication 类中的 DataSource 和 MetricRegistry 并将它们连接到 @PostConstruct 中:
@Autowired
private DataSource dataSource;
@Autowired
private MetricRegistry metricRegistry;
@PostConstruct
public void setUpHikariWithMetrics() {
if(dataSource instanceof HikariDataSource) {
((HikariDataSource) dataSource).setMetricRegistry(metricRegistry);
}
}
所以我能够通过在 java 配置文件中手动配置 HikariCP 来解决这个问题。这使我能够获得对 Spring Boot MetricRegistry 的引用,然后我可以在 HikariConfig 中设置它。这是我的配置类:
@Configuration
public class DatasourceConfiguration {
@Value("${spring.datasource.username}")
private String user;
@Value("${spring.datasource.password}")
private String password;
@Value("${spring.datasource.url}")
private String dataSourceUrl;
@Value("${spring.datasource.driverClassName}")
private String driverClassName;
@Value("${spring.datasource.connectionTestQuery}")
private String connectionTestQuery;
@Autowired
private MetricRegistry metricRegistry;
@Bean
public DataSource primaryDataSource() {
Properties dsProps = new Properties();
dsProps.setProperty("url", dataSourceUrl);
dsProps.setProperty("user", user);
dsProps.setProperty("password", password);
Properties configProps = new Properties();
configProps.setProperty("connectionTestQuery", connectionTestQuery);
configProps.setProperty("driverClassName", driverClassName);
configProps.setProperty("jdbcUrl", dataSourceUrl);
HikariConfig hc = new HikariConfig(configProps);
hc.setDataSourceProperties(dsProps);
hc.setMetricRegistry(metricRegistry);
return new HikariDataSource(hc);
}
}