springboot集成mybatis配置动态数据源出现连接线程数飚升的问题

最近在项目开发过程中,需要配置动态数据源,配置结束后发现数据库连接一直不断开,经过排查发现是没有配置一些参数,加上后就没有这样的问题了。

@Value("${spring.datasource.url}")
    private String defaultDBUrl;
    @Value("${spring.datasource.username}")
    private String defaultDBUser;
    @Value("${spring.datasource.password}")
    private String defaultDBPassword;
    @Value("${spring.datasource.driverClassName}")
    private String defaultDBDreiverName;
    
    //hikari 连接池属性
    //指定连接维护的最小空闲连接数,当使用HikariCP时指定.
    @Value("${spring.datasource.hikari.minimum-idle}")
    private int maximumIdle;
    //指定连接池最大的连接数,包括使用中的和空闲的连接.
    @Value("${spring.datasource.hikari.maximum-pool-size}")
    private int maximumPoolSize;
    //指定updates是否自动提交.
    @Value("${spring.datasource.hikari.auto-commit}")
    private boolean autoCommit;
    //指定连接多久没被使用时,被设置为空闲,默认为10ms
    @Value("${spring.datasource.hikari.idle-timeout}")
    private int idleTimeOut;
    //指定连接池名字.
    @Value("spring.datasource.hikari.pool-name}")
    private String poolName;
    //指定连接池中连接的最大生存时间,毫秒单位.
    @Value("${spring.datasource.hikari.max-lifetime}")
    private int maxLifeTime;
    //指定连接的超时时间,毫秒单位.
    @Value("${spring.datasource.hikari.connection-timeout}")
    private int ConnectionTimeOut;
    //指定校验连接合法性执行的sql语句
    @Value("spring.datasource.hikari.connection-test-query}")
    private String connectionTestQuery;
@Bean
    @Primary
    public DynamicDataSource dynamicDataSource() {
        DynamicDataSource dynamicDataSource = DynamicDataSource.getInstance();

        HikariDataSource  defaultDataSource = new HikariDataSource ();
        defaultDataSource.setJdbcUrl(defaultDBUrl);
        defaultDataSource.setUsername(defaultDBUser);
        defaultDataSource.setPassword(defaultDBPassword);
        defaultDataSource.setDriverClassName(defaultDBDreiverName);
        defaultDataSource.setMaximumPoolSize(maximumPoolSize);
    	defaultDataSource.setMinimumIdle(maximumIdle);
    	defaultDataSource.setIdleTimeout(idleTimeOut);
    	defaultDataSource.setMaxLifetime(maxLifeTime);
    	defaultDataSource.setAutoCommit(autoCommit);
    	defaultDataSource.setConnectionTimeout(ConnectionTimeOut);
    	defaultDataSource.setPoolName("默认主数据源连接池");
//    	defaultDataSource.setConnectionTestQuery(connectionTestQuery);


        Map<Object,Object> map = new HashMap<>();
        map.put("default", defaultDataSource);
        dynamicDataSource.setTargetDataSources(map);
        dynamicDataSource.setDefaultTargetDataSource(defaultDataSource);

        return dynamicDataSource;
    }

datasource相关配置:

  • spring.dao.exceptiontranslation.enabled
    是否开启PersistenceExceptionTranslationPostProcessor,默认为true

  • spring.datasource.abandon-when-percentage-full
    设定超时被废弃的连接占到多少比例时要被关闭或上报

  • spring.datasource.allow-pool-suspension
    使用Hikari pool时,是否允许连接池暂停,默认为: false

  • spring.datasource.alternate-username-allowed
    是否允许替代的用户名.

  • spring.datasource.auto-commit
    指定updates是否自动提交.

  • spring.datasource.catalog
    指定默认的catalog.

  • spring.datasource.commit-on-return
    设置当连接被归还时,是否要提交所有还未完成的事务

  • spring.datasource.connection-init-sql
    指定连接被创建,再被添加到连接池之前执行的sql.

  • spring.datasource.connection-init-sqls
    使用DBCP connection pool时,指定初始化时要执行的sql

  • spring.datasource.connection-properties.[key]
    在使用DBCP connection pool时指定要配置的属性

    扫描二维码关注公众号,回复: 6752676 查看本文章
  • spring.datasource.connection-test-query
    指定校验连接合法性执行的sql语句

  • spring.datasource.connection-timeout
    指定连接的超时时间,毫秒单位.

  • spring.datasource.continue-on-error
    在初始化数据库时,遇到错误是否继续,默认false

  • spring.datasource.data
    指定Data (DML)脚本

  • spring.datasource.data-source-class-name
    指定数据源的全限定名.

  • spring.datasource.data-source-jndi
    指定jndi的地址

  • spring.datasource.data-source-properties.[key]
    使用Hikari connection pool时,指定要设置的属性

  • spring.datasource.db-properties
    使用Tomcat connection pool,指定要设置的属性

  • spring.datasource.default-auto-commit
    是否自动提交.

  • spring.datasource.default-catalog
    指定连接默认的catalog.

  • spring.datasource.default-read-only
    是否设置默认连接只读.

  • spring.datasource.default-transaction-isolation
    指定连接的事务的默认隔离级别.

  • spring.datasource.driver-class-name
    指定driver的类名,默认从jdbc url中自动探测.

  • spring.datasource.fair-queue
    是否采用FIFO返回连接.

  • spring.datasource.health-check-properties.[key]
    使用Hikari connection pool时,在心跳检查时传递的属性

  • spring.datasource.idle-timeout
    指定连接多久没被使用时,被设置为空闲,默认为10ms

  • spring.datasource.ignore-exception-on-pre-load
    当初始化连接池时,是否忽略异常.

  • spring.datasource.init-sql
    当连接创建时,执行的sql

  • spring.datasource.initial-size
    指定启动连接池时,初始建立的连接数量

  • spring.datasource.initialization-fail-fast
    当创建连接池时,没法创建指定最小连接数量是否抛异常

  • spring.datasource.initialize
    指定初始化数据源,是否用data.sql来初始化,默认: true

  • spring.datasource.isolate-internal-queries
    指定内部查询是否要被隔离,默认为false

  • spring.datasource.jdbc-interceptors
    使用Tomcat connection pool时,指定jdbc拦截器,分号分隔

  • spring.datasource.jdbc-url
    指定JDBC URL.

  • spring.datasource.jmx-enabled
    是否开启JMX,默认为: false

  • spring.datasource.jndi-name
    指定jndi的名称.

  • spring.datasource.leak-detection-threshold
    使用Hikari connection pool时,多少毫秒检测一次连接泄露.

  • spring.datasource.log-abandoned
    使用DBCP connection pool,是否追踪废弃statement或连接,默认为: false

  • spring.datasource.log-validation-errors
    当使用Tomcat connection pool是否打印校验错误.

  • spring.datasource.login-timeout
    指定连接数据库的超时时间.

  • spring.datasource.max-active
    指定连接池中最大的活跃连接数.

  • spring.datasource.max-age
    指定连接池中连接的最大年龄

  • spring.datasource.max-idle
    指定连接池最大的空闲连接数量.

  • spring.datasource.max-lifetime
    指定连接池中连接的最大生存时间,毫秒单位.

  • spring.datasource.max-open-prepared-statements
    指定最大的打开的prepared statements数量.

  • spring.datasource.max-wait
    指定连接池等待连接返回的最大等待时间,毫秒单位.

  • spring.datasource.maximum-pool-size
    指定连接池最大的连接数,包括使用中的和空闲的连接.

  • spring.datasource.min-evictable-idle-time-millis
    指定一个空闲连接最少空闲多久后可被清除.

  • spring.datasource.min-idle
    指定必须保持连接的最小值(For DBCP and Tomcat connection pools)

  • spring.datasource.minimum-idle
    指定连接维护的最小空闲连接数,当使用HikariCP时指定.

  • spring.datasource.name
    指定数据源名.

  • spring.datasource.num-tests-per-eviction-run
    指定运行每个idle object evictor线程时的对象数量

  • spring.datasource.password
    指定数据库密码.

  • spring.datasource.platform
    指定schema要使用的Platform(schema-${platform}.sql),默认为: all

  • spring.datasource.pool-name
    指定连接池名字.

  • spring.datasource.pool-prepared-statements
    指定是否池化statements.

  • spring.datasource.propagate-interrupt-state
    在等待连接时,如果线程被中断,是否传播中断状态.

  • spring.datasource.read-only
    当使用Hikari connection pool时,是否标记数据源只读

  • spring.datasource.register-mbeans
    指定Hikari connection pool是否注册JMX MBeans.

  • spring.datasource.remove-abandoned
    指定当连接超过废弃超时时间时,是否立刻删除该连接.

  • spring.datasource.remove-abandoned-timeout
    指定连接应该被废弃的时间.

  • spring.datasource.rollback-on-return
    在归还连接时,是否回滚等待中的事务.

  • spring.datasource.schema
    指定Schema (DDL)脚本.

  • spring.datasource.separator
    指定初始化脚本的语句分隔符,默认: ;

  • spring.datasource.sql-script-encoding
    指定SQL scripts编码.

  • spring.datasource.suspect-timeout
    指定打印废弃连接前的超时时间.

  • spring.datasource.test-on-borrow
    当从连接池借用连接时,是否测试该连接.

  • spring.datasource.test-on-connect
    创建时,是否测试连接

  • spring.datasource.test-on-return
    在连接归还到连接池时是否测试该连接.

  • spring.datasource.test-while-idle
    当连接空闲时,是否执行连接测试.

  • spring.datasource.time-between-eviction-runs-millis
    指定空闲连接检查、废弃连接清理、空闲连接池大小调整之间的操作时间间隔

  • spring.datasource.transaction-isolation
    指定事务隔离级别,使用Hikari connection pool时指定

  • spring.datasource.url
    指定JDBC URL.

  • spring.datasource.use-disposable-connection-facade
    是否对连接进行包装,防止连接关闭之后被使用.

  • spring.datasource.use-equals
    比较方法名时是否使用String.equals()替换==.

  • spring.datasource.use-lock
    是否对连接操作加锁

  • spring.datasource.username
    指定数据库名.

  • spring.datasource.validation-interval
    指定多少ms执行一次连接校验.

  • spring.datasource.validation-query
    指定获取连接时连接校验的sql查询语句.

  • spring.datasource.validation-query-timeout
    指定连接校验查询的超时时间.

  • spring.datasource.validation-timeout
    设定连接校验的超时时间,当使用Hikari connection pool时指定

  • spring.datasource.validator-class-name
    用来测试查询的validator全限定名.

  • spring.datasource.xa.data-source-class-name
    指定数据源的全限定名.

  • spring.datasource.xa.properties
    指定传递给XA data source的属性

猜你喜欢

转载自blog.csdn.net/wangchaox123/article/details/94138331
今日推荐