SpringBoot 2.0 開始推 HikariCP ,將默認的數據庫鏈接池從 tomcat jdbc pool 改成了 hikari , HikariCP 在性能和併發方面確實表現不俗(號稱最快的鏈接池)。mysql
若是你使用 spring-boot-starter-jdbc 或 spring-boot-starter-data-jpa ,會自動添加對 HikariCP 的依賴,也就是說此時使用 HikariCP 。固然你也能夠強制使用其它的鏈接池技術,能夠經過在 application.properties 或 application.yml 中配置 spring.datasource.type 指定。spring
基本配置sql
由於已經默認使用 HikariCP,因此只須要在 yaml 中添加數據庫配置便可:數據庫
url: jdbc:mysql://localhost:3306?useSSL=false
username: root
password: 1234
HikariCP 默認配置tomcat
主要參數是在 com.zaxxer.hikari.HikariConfig 中初始化的,部分參數是在 com.zaxxer.hikari.pool.PoolBase 中初始化的。
springboot
springboot的HikariDataSource默認配置的默認值以下session
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 :app
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:spring-boot
@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(); }}