Spring Boot配置属性

摘要:springboot数据库连接池使用策略以及对应的配置属性

正文:

springboot数据库连接池使用策略

springboot官方文档介绍数据库连接池的使用策略如下: Production database connections can also be auto-configured using a pooling DataSource. Here’s the algorithm for choosing a specific implementation: We prefer the Tomcat pooling DataSource for its performance and concurrency, so if that is available we always choose it. If HikariCP is available we will use it. If Commons DBCP is available we will use it, but we don’t recommend it in production. Lastly, if Commons DBCP2 is available we will use it. If you use the spring-boot-starter-jdbc or spring-boot-starter-data-jpa ‘starter POMs’ you will automatically get a dependency to tomcat-jdbc.

  1. springboot会优先使用tomcat连接池,因为其性能和并发性很好,如果可用的话,将会优先使用。tomcat连接池,请查看: http://tomcat.apache.org/tomcat-8.0-doc/jdbc-pool.html
  2. 如果HikariCP可用,会选择使用 http://brettwooldridge.github.io/HikariCP/。
  3. 如果DBCP可用,会选择使用,但是不推荐在生产中使用它。
  4. 最后,如果使用DBCP2,会选择使用

如果在pom文件里有spring-boot-starter-jdbc 或者 spring-boot-starter-data-jpa 依赖项,那么,会自动获取tomcat-jdbc连接池。

springboot配置属性

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的属性JPA
  • spring.jpa.database指定目标数据库.
  • spring.jpa.database-platform指定目标数据库的类型.
  • spring.jpa.generate-ddl是否在启动时初始化schema,默认为false
  • spring.jpa.hibernate.ddl-auto指定DDL mode (none, validate, update, create, create-drop). 当使用内嵌数据库时,默认是create-drop,否则为none.
  • spring.jpa.hibernate.naming-strategy指定命名策略.
  • spring.jpa.open-in-view是否注册OpenEntityManagerInViewInterceptor,绑定JPA EntityManager到请求线程中,默认为: true
  • spring.jpa.properties添加额外的属性到JPA provider.
  • spring.jpa.show-sql是否开启sql的log,默认为: falsejooq
  • spring.jooq.sql-dialect指定JOOQ使用的SQLDialect,比如POSTGRES.h2
  • spring.h2.console.enabled是否开启控制台,默认为false
  • spring.h2.console.path指定控制台路径,默认为: /h2-consoleJTA
  • spring.jta.allow-multiple-lrc是否允许 multiple LRC,默认为: false
  • spring.jta.asynchronous2-pc指定两阶段提交是否可以异步,默认为: false
  • spring.jta.background-recovery-interval指定多少分钟跑一次recovery process,默认为: 1
  • spring.jta.background-recovery-interval-seconds指定多久跑一次recovery process,默认: 60
  • spring.jta.current-node-only-recovery是否过滤掉其他非本JVM的recovery,默认为: true
  • spring.jta.debug-zero-resource-transaction是否追踪没有使用指定资源的事务,默认为: false
  • spring.jta.default-transaction-timeout设定默认的事务超时时间,默认为60
  • spring.jta.disable-jmx是否禁用jmx,默认为false
  • spring.jta.enabled是否开启JTA support,默认为: true
  • spring.jta.exception-analyzer设置指定的异常分析类
  • spring.jta.filter-log-status使用Bitronix Transaction Manager时,是否写mandatory logs,开启的话,可以节省磁盘空间,但是调试会复杂写,默认为false
  • spring.jta.force-batching-enabled使用Bitronix Transaction Manager时,是否批量写磁盘,默认为true.
  • spring.jta.forced-write-enabled使用Bitronix Transaction Manager时,是否强制写日志到磁盘,默认为true
  • spring.jta.graceful-shutdown-interval当使用Bitronix Transaction Manager,指定shutdown时等待事务结束的时间,超过则中断,默认为60
  • spring.jta.jndi-transaction-synchronization-registry-name当使用Bitronix Transaction Manager时,在JNDI下得事务同步registry,默认为: java:comp/TransactionSynchronizationRegistry
  • spring.jta.jndi-user-transaction-name指定在JNDI使用Bitronix Transaction Manager的名称,默认:java:comp/UserTransaction
  • spring.jta.journal当使用Bitronix Transaction Manager,指定The journal是否disk还是null还是一个类的全限定名,默认disk
  • spring.jta.log-dirTransaction logs directory.
  • spring.jta.log-part1-filename指定The journal fragment文件1的名字,默认: btm1.tlog
  • spring.jta.log-part2-filename指定The journal fragment文件2的名字,默认: btm2.tlog
  • spring.jta.max-log-size-in-mb指定journal fragments大小的最大值. 默认: 2M
  • spring.jta.resource-configuration-filename指定Bitronix Transaction Manager配置文件名.
  • spring.jta.server-id指定Bitronix Transaction Manager实例的id.
  • spring.jta.skip-corrupted-logs是否忽略corrupted log files文件,默认为false.
  • spring.jta.transaction-manager-id指定Transaction manager的唯一标识.
  • spring.jta.warn-about-zero-resource-transaction当使用Bitronix Transaction Manager时,是否对没有使用指定资源的事务进行警告,默认为: true

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏极客日常

利用Hugo和Github Pages免费创建并永久托管网站

Hugo可以让你轻松生成静态网站,比如个人博客、API文档、公司主页等,你只需要提供markdown格式的文本,它就能帮你渲染成各种你想要的样式,只需要安装想...

1.6K10
来自专栏黑泽君的专栏

解决 Maven工程运行报错Failed to clean project: Failed to delete

  在运行maven工程总是报“Failed to clean project: Failed to delete”错误,原因是因为之前编译的工程还在运行,无法...

15730
来自专栏醉生梦死

centos7服务器主网卡绑定多ip实践演示

2.9K90
来自专栏蓝天

两个openssh间免密码登录

以下针对的是openssh,而不是ssh,也不是ssh2。配置分两部分:一是对登录机的配置,二是对被登录机的配置,其中登录机为客户端,被登录机为服务端,也就是解...

10020
来自专栏IMWeb前端团队

websocket 协议解析

本文作者:IMWeb went 原文出处:IMWeb社区 未经同意,禁止转载 1.使用websocket 场景 websocket作为用于双向通信的实...

32970
来自专栏雨过天晴

原 个人新服务器用户配置

17220
来自专栏云计算教程系列

如何在Ubuntu 16.04上使用Apache和mod_wsgi为Django应用程序提供服务

Django是一个功能强大的Web框架,可以帮助您快速启动Python应用程序或网站。Django包含一个简化的开发服务器,用于在本地测试您的代码,但是对于任何...

17200
来自专栏xingoo, 一个梦想做发明家的程序员

linux虚拟机与winodows共享文件夹----linux安装VMware tools

虚拟机里面想要获取原来本机 系统的文件,十分麻烦。为了实现原系统与虚拟机的共享文件夹,可以通过安装vmware tools达到共享目的。 1 安装vmware ...

25890
来自专栏Go 语言编程

aurora - 跨平台 Beanstalk 消息队列服务器管理工具

aurora 是一个基于 Web 的 Beanstalk 消息队列服务器管理工具,单文件无需依赖其他组件,支持管理本地和远程多个队列服务器。

60770
来自专栏web编程技术分享

【Java框架型项目从入门到装逼】第三节 - 如何用Tomcat发布web项目?

40880

扫码关注云+社区

领取腾讯云代金券