springBoot数据库连接池常用配置

在配置文件中添加配置如下(我使用的是多数据源):

spring.datasource.primary.url=jdbc\:mysql\://localhost\:3306/test?useUnicode\=true&characterEncoding\=utf-8
spring.datasource.primary.username=test
spring.datasource.primary.password=123456
spring.datasource.primary.driver-class-name=com.mysql.jdbc.Driver
#验证连接的有效性
spring.datasource.primary.test-while-idle=true
#获取连接时候验证,会影响性能
spring.datasource.primary.test-on-borrow=false
#在连接归还到连接池时是否测试该连接
spring.datasource.primary.test-on-return=false
spring.datasource.primary.validation-query=SELECT 1 FROM DUAL
#空闲连接回收的时间间隔,与test-while-idle一起使用,设置5分钟
spring.datasource.primary.time-between-eviction-runs-millis=300000
#连接池空闲连接的有效时间 ,设置30分钟
spring.datasource.primary.min-evictable-idle-time-millis=1800000
spring.datasource.primary.initial-size=5
#指定连接池中最大的活跃连接数.
spring.datasource.primary.max-active=50
#指定连接池等待连接返回的最大等待时间,毫秒单位.
spring.datasource.primary.max-wait=60000
#指定必须保持连接的最小值
spring.datasource.primary.min-idle=5

spring.datasource.secondary.url=jdbc\:mysql\://localhost\:3306/test2?useUnicode\=true&characterEncoding\=utf-8
spring.datasource.secondary.username=test
spring.datasource.secondary.password=123456
spring.datasource.secondary.driver-class-name=com.mysql.jdbc.Driver
#验证连接的有效性
spring.datasource.secondary.test-while-idle=true
#获取连接时候验证,会影响性能
spring.datasource.secondary.test-on-borrow=false
#在连接归还到连接池时是否测试该连接
spring.datasource.secondary.test-on-return=false
spring.datasource.secondary.validation-query=SELECT 1 FROM DUAL
#空闲连接回收的时间间隔,与test-while-idle一起使用,设置5分钟
spring.datasource.secondary.time-between-eviction-runs-millis=300000
#连接池空闲连接的有效时间 ,设置30分钟
spring.datasource.secondary.min-evictable-idle-time-millis=1800000
spring.datasource.secondary.initial-size=5
#指定连接池中最大的活跃连接数.
spring.datasource.secondary.max-active=50
#指定连接池等待连接返回的最大等待时间,毫秒单位.
spring.datasource.secondary.max-wait=60000
#指定必须保持连接的最小值
spring.datasource.secondary.min-idle=5

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时指定要配置的属性
  • 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的属性
时间: 2024-11-05 17:23:28

springBoot数据库连接池常用配置的相关文章

Spring整合HIbernate时,三种数据库连接池的配置和比较

现在常用的开源数据库连接池主要有c3p0.dbcp.proxool三种,其中: Spring                         推荐使用dbcp: Hibernate                  推荐使用c3p0和proxool: 1.  DBCP:Apache DBCP(DataBase connection pool)数据库连接池.是Apache上的一个 java连接池项目,也是 tomcat使用的连接池组件.单独使用dbcp需要3个包:common-dbcp.jar,c

数据库连接池的配置

一.什么是数据库连接池? 官方:数据库连接池(Connection pooling)是程序启动时建立足够的数据库连接,并将这些连接组成一个连接池,由程序动态地对池中的连接进行申请,使用,释放.个人理解:创建数据库连接是一个很耗时的操作,也容易对数据库造成安全隐患.所以,在程序初始化的时候,集中创建多个数据库连接,并把他们集中管理,供程序使用,可以保证较快的数据库读写速度,还更加安全可靠. 二.为何要使用数据库连接池? 假设网站一天有很大的访问量,数据库服务器就需要为每次连接创建一次数据库连接,极

[转]阿里巴巴数据库连接池 druid配置详解

一.背景 java程序很大一部分要操作数据库,为了提高性能操作数据库的时候,又不得不使用数据库连接池.数据库连接池有很多选择,c3p.dhcp.proxool等,druid作为一名后起之秀,凭借其出色的性能,也逐渐映入了大家的眼帘.接下来本教程就说一下druid的简单使用. 二.jar包下载.配置详解及配置示例 1.jar获取 可以从 http://repo1.maven.org/maven2/com/alibaba/druid/ 下载最新的jar包.如果想使用最新的源码编译,也可以从 http

三种数据库连接池的配置及使用(For JDBC)

DBCP 一.导包 Apache官网下载DBCP包,导入两个包路径如下: commons-dbcp-1.4-bin\commons-dbcp-1.4\commons-dbcp-1.4.jar:连接池的实现 commons-pool-1.5.6-bin\commons-pool-1.5.6\commons-pool-1.5.6.jar:连接池实现的依赖库 CSDN上jar包的下载地址:http://download.csdn.NET/detail/u012802702/9491642 二.代码示例

Springboot pom.xml 常用配置 (一)

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersi

SpringBoot中的常用配置

一 . 关于在application.properties文件中的一些常见配置 1.server.port=8888   :表示配置端口 2.server.context-path 表示自定义上下文路径 3.server.tomcat.uri-encoding = UTF-8        表示用于解码URI的字符编码. 4.spring.http.encoding.charset = UTF-8 #HTTP请求和响应的字符集.如果未明确设置,则添加到"Content-Type"头.

spring-boot logback日志常用配置解释

1)引入 spring-boot默认日志系统就是logback日志框架 spring-boot引入logback的maven依赖关系树如下: 2)配置 在application.properties文件中 #backlog setting logging.config=logback-spring.xml 或者在 application-dev.yml文件中 logging: config: classpath:logback-spring.xml logback-spring.xml配置详解

spring c3p0数据库连接池连接配置

c3p0连接池配置 xml文件内容如下: C3P0拥有比DBCP更丰富的配置属性,通过这些属性,可以对数据源进行各种有效的控制: acquireIncrement:当连接池中的连接用完时,C3P0一次性创建新连接的数目: acquireRetryAttempts:定义在从数据库获取新连接失败后重复尝试获取的次数,默认为30: acquireRetryDelay:两次连接中间隔时间,单位毫秒,默认为1000: autoCommitOnClose:连接关闭时默认将所有未提交的操作回滚.默认为fals

【java servlet】在java servlet中配置数据库连接池的配置(在server.xml)

<Context path="/" docBase="" debug="0"> <!-- name:给出数据源设置名字: auth:表示该数据源是由谁管理:type:表示类型--> <Resource name="zhaoyan" auth="Container" type="javax.sql.DataSource"/> <ResourcePa