HikariCP配置詳解+多數據源


SpringBoot 2.0 開始推 HikariCP ,將默認的數據庫連接池從 tomcat jdbc pool 改為了 hikari , HikariCP 在性能和並發方面確實表現不俗(號稱最快的連接池)。

如果你使用 spring-boot-starter-jdbc 或 spring-boot-starter-data-jpa ,會自動添加對 HikariCP 的依賴,也就是說此時使用 HikariCP 。當然你也可以強制使用其它的連接池技術,可以通過在 application.properties 或 application.yml 中配置 spring.datasource.type 指定。

基本配置

因為已經默認使用 HikariCP,所以只需要在 yaml 中添加數據庫配置即可:

url: jdbc:mysql://localhost:3306?useSSL=false
username: root
password: 1234

HikariCP 默認配置

主要參數是在 com.zaxxer.hikari.HikariConfig 中初始化的,部分參數是在 com.zaxxer.hikari.pool.PoolBase 中初始化的。

springboot的HikariDataSource默認配置的默認值如下

name 構造器默認值 默認配置validate之后的值 validate重置
minIdle -1 10 minIdle<0或者minIdle>maxPoolSize,則被重置為maxPoolSize
maxPoolSize -1 10 如果maxPoolSize小於1,則會被重置。當minIdle<=0被重置為DEFAULT_POOL_SIZE則為10;如果minIdle>0則重置為minIdle的值
maxLifetime MINUTES.toMillis(30) = 1800000 1800000 如果不等於0且小於30秒則會被重置回30分鍾
connectionTimeout SECONDS.toMillis(30) = 30000 30000 如果小於250毫秒,則被重置回30秒
validationTimeout SECONDS.toMillis(5) = 5000 5000 如果小於250毫秒,則會被重置回5秒
loginTimeout 10 30 Math.max(1, (int) MILLISECONDS.toSeconds(500L + connectionTimeout)),為connectionTimeout+500ms轉為秒數取整 與 1 取最大者
idleTimeout MINUTES.toMillis(10) = 600000 600000 如果idleTimeout+1秒>maxLifetime 且 maxLifetime>0,則會被重置為0;如果idleTimeout!=0且小於10秒,則會被重置為10秒
leakDetectionThreshold 0 0 如果大於0且不是單元測試,則進一步判斷:(leakDetectionThreshold < SECONDS.toMillis(2) or (leakDetectionThreshold > maxLifetime && maxLifetime > 0),會被重置為0 . 即如果要生效則必須>0,而且不能小於2秒,而且當maxLifetime > 0時不能大於maxLifetime
initializationFailTimeout 1 1 -
isAutoCommit true true -
isReadOnly false fasle -
isAllowPoolSuspension false false -
isIsolateInternalQueries false false -
isRegisterMbeans false false -
sealed false true 運行啟動后這個標志為true,表示不再運行修改
poolName null HikariPool-1 -
catalog null null -
connectionInitSql null null -
connectionTestQuery null null -
dataSourceClassName null null -
schema null null -
transactionIsolationName null null -
dataSource null null -
dataSourceProperties {} {} -
threadFactory null null -
scheduledExecutor null null -
metricsTrackerFactory null null -
metricRegistry null null -
healthCheckRegistry null null -
healthCheckProperties {} {} -

 

HikariCP 配置多數據源

application.yml :

hikari:
primary:
jdbc-url: jdbc:mysql://localhost:3306/xu?useSSL=false
username: root
password: 1234
second:
jdbc-url: jdbc:mysql://localhost:3306/hua?useSSL=false
username: root
password: 1234

PrimaryDatasourceConfig:

@Configuration
@MapperScan(basePackages = PrimaryDatasourceConfig.PACKAGE,sqlSessionFactoryRef = "primarySqlSessionFactory")
public class PrimaryDatasourceConfig {

static final String PACKAGE = "com.xu.scaffold.repository.primary";

@Bean(name = "primaryDataSource")
@Primary
@ConfigurationProperties(prefix = "hikari.primary")
public HikariDataSource dataSource() {
return new HikariDataSource();
}

@Bean(name = "primaryTransactionManager")
@Primary
public DataSourceTransactionManager transactionManager() {
return new DataSourceTransactionManager(this.dataSource());
}

@Bean(name = "primarySqlSessionFactory")
@Primary
public SqlSessionFactory sqlSessionFactory(@Qualifier("primaryDataSource") DataSource dataSource) throws Exception {
final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
sessionFactory.setDataSource(dataSource);
sessionFactory.getObject().getConfiguration().setMapUnderscoreToCamelCase(true);
return sessionFactory.getObject();
}
}


SecondDatasourceConfig:

@Configuration
@MapperScan(basePackages = SecondDatasourceConfig.PACKAGE, sqlSessionFactoryRef = "secondSqlSessionFactory")
public class SecondDatasourceConfig {

static final String PACKAGE = "com.xu.scaffold.repository.second";

@Bean(name = "secondDataSource")
@ConfigurationProperties(prefix = "hikari.second")
public HikariDataSource dataSource() {
return new HikariDataSource();
}

@Bean(name = "secondTransactionManager")
public DataSourceTransactionManager transactionManager() {
return new DataSourceTransactionManager(this.dataSource());
}

@Bean(name = "secondSqlSessionFactory")
public SqlSessionFactory sqlSessionFactory(@Qualifier("secondDataSource") DataSource dataSource) throws Exception {
final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
sessionFactory.setDataSource(dataSource);
sessionFactory.getObject().getConfiguration().setMapUnderscoreToCamelCase(true);
return sessionFactory.getObject();
}
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM