SpringBoot数据库连接池常用配置

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 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的属性


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
2月前
|
Oracle 关系型数据库 Linux
【赵渝强老师】Oracle数据库配置助手:DBCA
Oracle数据库配置助手(DBCA)是用于创建和配置Oracle数据库的工具,支持图形界面和静默执行模式。本文介绍了使用DBCA在Linux环境下创建数据库的完整步骤,包括选择数据库操作类型、配置存储与网络选项、设置管理密码等,并提供了界面截图与视频讲解,帮助用户快速掌握数据库创建流程。
324 93
|
5月前
|
关系型数据库 MySQL 数据库连接
Django数据库配置避坑指南:从初始化到生产环境的实战优化
本文介绍了Django数据库配置与初始化实战,涵盖MySQL等主流数据库的配置方法及常见问题处理。内容包括数据库连接设置、驱动安装、配置检查、数据表生成、初始数据导入导出,并提供真实项目部署场景的操作步骤与示例代码,适用于开发、测试及生产环境搭建。
213 1
|
4月前
|
Java Spring
Spring Boot配置的优先级?
在Spring Boot项目中,配置可通过配置文件和外部配置实现。支持的配置文件包括application.properties、application.yml和application.yaml,优先级依次降低。外部配置常用方式有Java系统属性(如-Dserver.port=9001)和命令行参数(如--server.port=10010),其中命令行参数优先级高于系统属性。整体优先级顺序为:命令行参数 > Java系统属性 > application.properties > application.yml > application.yaml。
909 0
|
1月前
|
JavaScript Java Maven
【SpringBoot(二)】带你认识Yaml配置文件类型、SpringMVC的资源访问路径 和 静态资源配置的原理!
SpringBoot专栏第二章,从本章开始正式进入SpringBoot的WEB阶段开发,本章先带你认识yaml配置文件和资源的路径配置原理,以方便在后面的文章中打下基础
256 3
|
2月前
|
Ubuntu 安全 关系型数据库
安装与配置MySQL 8 on Ubuntu,包括权限授予、数据库备份及远程连接指南
以上步骤提供了在Ubuntu上从头开始设置、配置、授权、备份及恢复一个基础但完整的MySQL环境所需知识点。
383 7
|
2月前
|
缓存 Java 应用服务中间件
Spring Boot配置优化:Tomcat+数据库+缓存+日志,全场景教程
本文详解Spring Boot十大核心配置优化技巧,涵盖Tomcat连接池、数据库连接池、Jackson时区、日志管理、缓存策略、异步线程池等关键配置,结合代码示例与通俗解释,助你轻松掌握高并发场景下的性能调优方法,适用于实际项目落地。
510 5
|
2月前
|
传感器 Java 数据库
探索Spring Boot的@Conditional注解的上下文配置
Spring Boot 的 `@Conditional` 注解可根据不同条件动态控制 Bean 的加载,提升应用的灵活性与可配置性。本文深入解析其用法与优势,并结合实例展示如何通过自定义条件类实现环境适配的智能配置。
168 0
探索Spring Boot的@Conditional注解的上下文配置
|
3月前
|
安全 算法 Java
在Spring Boot中应用Jasypt以加密配置信息。
通过以上步骤,可以在Spring Boot应用中有效地利用Jasypt对配置信息进行加密,这样即使配置文件被泄露,其中的敏感信息也不会直接暴露给攻击者。这是一种在不牺牲操作复杂度的情况下提升应用安全性的简便方法。
947 10
|
5月前
|
安全 Java 数据库
Jasypt加密数据库配置信息
本文介绍了使用 Jasypt 对配置文件中的公网数据库认证信息进行加密的方法,以提升系统安全性。主要内容包括:1. 背景介绍;2. 前期准备,如依赖导入及版本选择;3. 生成密钥并实现加解密测试;4. 在配置文件中应用加密后的密码,并通过测试接口验证解密结果。确保密码安全的同时,保障系统的正常运行。
371 3
Jasypt加密数据库配置信息
|
4月前
|
人工智能 安全 Java
Spring Boot yml 配置敏感信息加密
本文介绍了如何在 Spring Boot 项目中使用 Jasypt 实现配置文件加密,包含添加依赖、配置密钥、生成加密值、在配置中使用加密值及验证步骤,并提供了注意事项,确保敏感信息的安全管理。
1088 1