zoukankan      html  css  js  c++  java
  • 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();
    }
    }

  • 相关阅读:
    高级选项更改MathType数学公式样式
    tp 批量转码
    create the web service by yourshelf
    云通讯 添加群组
    sql 更新字段
    op bug 修复计划
    php ut8声明
    PHP 包含文件
    php 判断查询结果是否为空
    合并列值
  • 原文地址:https://www.cnblogs.com/toughzcf/p/10002240.html
Copyright © 2011-2022 走看看