SpringBoot数据库连接池常用配置

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 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的属性


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
消息中间件 缓存 监控
28 0
|
14天前
|
SQL 关系型数据库 分布式数据库
PolarDB Proxy配置与优化:提升数据库访问效率
【9月更文挑战第6天】PolarDB是阿里云推出的高性能分布式关系型数据库,PolarDB Proxy作为其关键组件,位于客户端与PolarDB集群间,负责SQL请求的解析与转发,并支持连接池管理、SQL过滤及路由规则等功能。本文详细介绍了PolarDB Proxy的配置方法,包括连接池、负载均衡和SQL过滤设置,并探讨了监控调优、缓存及网络优化策略,以帮助提升数据库访问效率。
24 1
|
18天前
|
IDE Java 开发工具
还在为繁琐的配置头疼吗?一文教你如何用 Spring Boot 快速启动,让开发效率飙升,从此告别加班——打造你的首个轻量级应用!
【9月更文挑战第2天】Spring Boot 是一款基于 Spring 框架的简化开发工具包,采用“约定优于配置”的原则,帮助开发者快速创建独立的生产级应用程序。本文将指导您完成首个 Spring Boot 项目的搭建过程,包括环境配置、项目初始化、添加依赖、编写控制器及运行应用。首先需确保 JDK 版本不低于 8,并安装支持 Spring Boot 的现代 IDE,如 IntelliJ IDEA 或 Eclipse。
57 5
|
19天前
|
Java 数据库连接 数据库
数据库以及其他项目配置
该项目配置了数据库连接和MyBatis设置,并解决了配置文件加载问题。启动类使用 `@SpringBootApplication` 注解,可通过 `@ComponentScan` 指定扫描包。Lombok 自动生成 getter/setter 等方法,简化代码。Result 实体类用于统一返回格式。用户模块包括注册与登录功能,使用 MD5 加密密码、Spring Validation 参数校验及 JWT 认证。JWT 工具类处理令牌生成与解析,并通过拦截器验证。Redis 优化登录功能,利用 ThreadLocal 存储用户信息。此外,还包括文章模块的相关功能,如文章分类管理、
36 2
|
29天前
|
关系型数据库 MySQL Linux
在Linux中,如何配置数据库服务器(如MySQL或PostgreSQL)?
在Linux中,如何配置数据库服务器(如MySQL或PostgreSQL)?
|
27天前
|
JavaScript Java 关系型数据库
毕设项目&课程设计&毕设项目:基于springboot+vue实现的前后端分离的考试管理系统(含教程&源码&数据库数据)
在数字化时代背景下,本文详细介绍了如何使用Spring Boot框架结合Vue.js技术栈,实现一个前后端分离的考试管理系统。该系统旨在提升考试管理效率,优化用户体验,确保数据安全及可维护性。技术选型包括:Spring Boot 2.0、Vue.js 2.0、Node.js 12.14.0、MySQL 8.0、Element-UI等。系统功能涵盖登录注册、学员考试(包括查看试卷、答题、成绩查询等)、管理员功能(题库管理、试题管理、试卷管理、系统设置等)。
毕设项目&课程设计&毕设项目:基于springboot+vue实现的前后端分离的考试管理系统(含教程&源码&数据库数据)
|
7天前
|
SQL 关系型数据库 MySQL
MySQL技术安装配置、数据库与表的设计、数据操作解析
MySQL,作为最流行的关系型数据库管理系统之一,在WEB应用领域中占据着举足轻重的地位。本文将从MySQL的基本概念、安装配置、数据库与表的设计、数据操作解析,并通过具体的代码示例展示如何在实际项目中应用MySQL。
34 0
|
20天前
|
Java Spring 开发者
解锁 Spring Boot 自动化配置的黑科技:带你走进一键配置的高效开发新时代,再也不怕繁琐设置!
【8月更文挑战第31天】Spring Boot 的自动化配置机制极大简化了开发流程,使开发者能专注业务逻辑。通过 `@SpringBootApplication` 注解组合,特别是 `@EnableAutoConfiguration`,Spring Boot 可自动激活所需配置。例如,添加 JPA 依赖后,只需在 `application.properties` 配置数据库信息,即可自动完成 JPA 和数据源设置。这一机制基于多种条件注解(如 `@ConditionalOnClass`)实现智能配置。深入理解该机制有助于提升开发效率并更好地解决问题。
34 0
|
22天前
|
缓存 Java 数据库连接
Spring Boot 资源文件属性配置,紧跟技术热点,为你的应用注入灵动活力!
【8月更文挑战第29天】在Spring Boot开发中,资源文件属性配置至关重要,它让开发者能灵活定制应用行为而不改动代码,极大提升了可维护性和扩展性。Spring Boot支持多种配置文件类型,如`application.properties`和`application.yml`,分别位于项目的resources目录下。`.properties`文件采用键值对形式,而`yml`文件则具有更清晰的层次结构,适合复杂配置。此外,Spring Boot还支持占位符引用和其他外部来源的属性值,便于不同环境下覆盖默认配置。通过合理配置,应用能快速适应各种环境与需求变化。
27 0